Jquery cookie监视器

前端之家收集整理的这篇文章主要介绍了Jquery cookie监视器前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
什么是最好的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

猜你在找的jQuery相关文章