¿Cuál es el mejor enfoque específico de JS o JQuery para monitorear una cookie durante toda la vida de la página en el navegador y desencadenar un evento cuando la cookie se 'cambia?Monitor de cookies Jquery
Respuesta
Hasta donde yo sé, no es posible enlazar directamente un evento change
(o similar) a una cookie. En cambio, me gustaría obtener este enfoque:
Cree un sondeo que compare el valor de la cookie con el valor conocido previamente cada X milisegundos.
// basic functions from the excellent http://www.quirksmode.org/js/cookies.html
function readCookie(name) {
var nameEQ = name + "=";
var ca = document.cookie.split(';');
for(var i=0;i < ca.length;i++) {
var c = ca[i];
while (c.charAt(0)==' ') c = c.substring(1,c.length);
if (c.indexOf(nameEQ) == 0) return c.substring(nameEQ.length,c.length);
}
return null;
}
/////////////////////////////////
// ACTUAL FUN STUFF BELOW
/////////////////////////////////
var cookieRegistry = [];
function listenCookieChange(cookieName, callback) {
setInterval(function() {
if (cookieRegistry[cookieName]) {
if (readCookie(cookieName) != cookieRegistry[cookieName]) {
// update registry so we dont get triggered again
cookieRegistry[cookieName] = readCookie(cookieName);
return callback();
}
} else {
cookieRegistry[cookieName] = readCookie(cookieName);
}
}, 100);
}
uso sería entonces algo como esto:
listenCookieChange('foo', function() {
alert('cookie foo has changed!');
});
Nota: esto no ha sido probado y es sólo una pequeña demostración de cómo iba a abordar el problema.
EDIT: He probado esto ahora y funciona.See example :)
Hay un jQuery
complemento para cookies
.
http://plugins.jquery.com/project/Cookie
No es difícil acceder a las cookies en un documento HTML, viven en document.cookie
.
<!-- Add cookie -->
$.cookie('cookieName':'cookieValue');
<!-- get cookie -->
$.cookie('cookieName');
<!-- removecookie -->
$.cookie('cookieName', null);
Además, hay opciones de argumentos para agregar una cookie, p. Ej. expiración.
Sin embargo, en respuesta a su pregunta, no creo que pueda aplicar un detector de eventos a las cookies, lamentablemente.
Su código tiene mala sintaxis. Está utilizando comentarios html en javascript y los dos puntos entre ''cookieName'' y'' cookieValue'' en el primer ejemplo deben ser una coma. Esa puede ser la razón del voto a la baja. – benekastah
Sepa qué, esto ayudó a algo raro. Intenté usar Google Translate (http://translate.google.com/translate_tools?hl=es) en una aplicación web móvil y cada vez que se cambia el idioma, se siguió insertando una barra en la parte superior como el primer elemento secundario del documento. cuerpo . Ahora estoy rastreando la cookie 'googtrans' y haciendo esto
listenCookieChange('googtrans', function() {
$(document.body).css('top','0px');
});
- 1. jquery, eliminar cookies
- 2. Creación de cookies a través de jquery
- 3. Jquery parada HTML codificación de cookies
- 4. ¿Cookies de sesión = cookies?
- 5. jQuery cookie plugin - $ cookies no está definido
- 6. Cómo borrar todas las cookies con jQuery
- 7. ¿jQuery envía cookies en una publicación?
- 8. monitor de impresión
- 9. Monitor de red gratuito
- 10. Monitor de RSS específica
- 11. Cookies de Javascript vs cookies de php
- 12. ¿Es posible implementar "Recordarme" usando las cookies de jquery?
- 13. iphone nsurlconnection leer cookies
- 14. Clase de monitor en Java
- 15. Monitor de túnel SSH inverso
- 16. Monitor IIS 6.0
- 17. Monitor Network Traffic Mac
- 18. commit monitor para tfs
- 19. MBean Simple Graph Monitor
- 20. .NET Process Monitor
- 21. Encender/apagar el monitor
- 22. ¿Puede jQuery leer/escribir cookies en un navegador?
- 23. Pyramid.security questions: Double cookies? ¿Cookies inseguras? ¿Vencimiento?
- 24. monitor de cambio de tabla de Oracle
- 25. ¿Cómo usar gdb como monitor?
- 26. Diferencia entre monitor y bloqueo?
- 27. Estadísticas/Monitor/Inspector para beanstalkd
- 28. GIT Log o Commit Monitor
- 29. C#: Monitor - Espera, pulso, PulseAll
- 30. Uso de datos de monitor (internet)
Nota: Esto solo se activa en eventos de cambio de cookies. Necesitaba comprobar también ** la creación de cookies ** y modifiqué el código así: '... if (cookieRegistry [cookieName] || readCookie (cookieName)! = Null) {...' –
Hola Aron, gracias por esto bien! Realmente gracias. Es 2017 y estoy enfrentando un problema con la regla de eslint sobre 'consistente-return' para' listenCookieChange() 'donde' setInterval' es. ¿Podrías actualizar tu respuesta para hacer feliz a eslint? Deshabilitar eslint funciona. – Sylar