Cookie每隔30天显示一次弹出窗口

时间:2012-10-17 02:12:24

标签: javascript jquery cookies

<script type="text/javascript">
jQuery(document).ready(function(){
if (document.cookie.indexOf('visited=false') == -1)
{
var fifteenDays = 1000*60*60*24*30;
var expires = new Date((new Date()).valueOf() + fifteenDays);
document.cookie = "visited=true;expires=" + expires.toUTCString();
$.colorbox({width:"400px", inline:true, href:"#exestylepopups"});
}
});
</script>

我的上述代码出了什么问题每次在我的博客中加载页面时都会调用我的facebook这样的popup。我只是每30天只展示一次。我怎么能这样做?

1 个答案:

答案 0 :(得分:4)

您的特定实现看起来像是在检查'visited=false'的Cookie,但是将Cookie设置为'visited=true',因此您的if语句永远不会匹配。


我建议您使用经过验证的一组Cookie操作函数,然后您的任务就会非常简单。

以下是我的环境尚未拥有的cookie函数:

function createCookie(name,value,days) {
    if (days) {
        var date = new Date();
        date.setTime(date.getTime()+(days*24*60*60*1000));
        var expires = "; expires="+date.toGMTString();
    }
    else var expires = "";
    document.cookie = name+"="+value+expires+"; path=/";
}

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;
}

function eraseCookie(name) {
    createCookie(name,"",-1);
}

有了这些,你可以这样做:

jQuery(document).ready(function() {
    var visited = readCookie('visited');
    if (!visited || visited !== "true") {
        createCookie('visited', "true", 30);
        $.colorbox({width:"400px", inline:true, href:"#exestylepopups"});
    }
});