sessionStorage工作但需要一个cookie

时间:2013-10-11 08:49:37

标签: jquery cookies modal-dialog session-storage

所以我有以下代码执行我需要它但现在已被告知它需要在ie7中工作而sessionStorage在该浏览器中不起作用。我对饼干知之甚少,所以想知道是否有人能指出我正确的方向。

    var yetVisited = sessionStorage['visited'];
    if (!yetVisited) {

        $j("#adspaceModal").modal("show").on("shown", function () {
    window.setTimeout(function () {
        $j("#adspaceModal").modal("hide");
    }, 20000);
});

        // open popup
        sessionStorage['visited'] = "yes";
    }

目前,当我第一次访问主页时,我的模态显示,并且除非我在新的标签/窗口中打开它,否则它不会出现,这取决于我想要的方式。

非常感谢任何帮助。

1 个答案:

答案 0 :(得分:3)

您可以使用功能检测来确定sessionStorage是否可用,如果不使用jQuery Cookie plugin

var yetVisited = sessionStorage ? sessionStorage['visited'] : $.cookie('visited');
if (!yetVisited) {
    $j("#adspaceModal").modal("show").on("shown", function () {
        window.setTimeout(function () {
            $j("#adspaceModal").modal("hide");
        }, 20000);
    });

    // open popup
    sessionStorage ? sessionStorage['visited'] = 'yes' : $.cookie('visited', 'yes');
}

事实上,将它抽象为它自己的函数可能更好:

function storage(key, value) {
    if (!value) {
        // getter
        return window.sessionStorage ? window.sessionStorage[key] : $.cookie(key);
    } 
    else { 
        // setter
        window.sessionStorage ? window.sessionStorage[key] = value : $.cookie(key, value);
    }
}