什么是最好的JS或JQuery特定的方法来监控cookie在整个浏览器的页面生命周期并触发事件,当cookie被’更改?
解决方法
据我所知,不可能直接将更改(或类似)事件绑定到cookie.相反,我会采用这种方法:
创建一个轮询器,每隔X毫秒将cookie值与先前已知的值进行比较.
// 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); }
用法将是这样的:
listenCookieChange('foo',function() { alert('cookie foo has changed!'); });
注意:这尚未经过测试,只是我将如何解决问题的快速演示.
编辑:我现在测试了它,它的工作原理. See example 版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。