javascript - GetCookie 返回 NULL

标签 javascript jquery jquery-plugins cookies

我尝试在 Javascript 和 Jquery 中设置和获取 Cookie,但这两种方法都返回 null。我的代码看起来是正确的,但我不知道为什么它对我不起作用。

cook.js

function setCookie(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 getCookie(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 deleteCookie(name) {
    setCookie(name,"",-1);
}

和我的 html 页面:

fin.html :

<!DOCTYPE html>
<html>
    <head>
        <title>My Page</title> 
        <meta name="viewport" content="width=device-width, initial-scale=1"> 
        <script type="text/javascript" src="jquery-1.7.1.min.js"></script>
        <script type="text/javascript" src="jquery.cookie.js"></script>
        <script type="text/javascript" src="cook.js"></script>
    </head>
    <body>
        <a id="setcookie" href="fin2.html">SET COOKIE</a>
        <script>
            $("#setcookie").click(function() {
                // Using javascript function
                setCookie("mycookie", "itsvalue", 1) ;

                // Using jQuery plugin
                $.cookie('myCookie2': "myValue");
            });
        </script>
     </body>
</html>

fin2.html

<!DOCTYPE html>
<html>
    <head>
        <title>My Page</title> 
        <meta name="viewport" content="width=device-width, initial-scale=1"> 
        <script type="text/javascript" src="jquery-1.7.1.min.js"></script>
        <script type="text/javascript" src="jquery.cookie.js"></script>
        <script type="text/javascript" src="cook.js"></script>      
    </head>
    <body>
        <a id="get" href="#">YOO</a>
        <script>
            $("#get").click(function() {
                alert(getCookie("mycookie")) ;
                alert($.cookie('myCookie')) ;
            }) ;
        </script>
    </body>
</html>

但它使用 jquery 插件和 javscript 函数返回 null。你知道这个问题吗?非常感谢:)

最佳答案

默认情况下,jQuery cookie 插件使用当前路径设置 cookie 作为路径的默认值。这意味着 cookie 将仅在设置它的同一页面上可用。如果您希望 cookie 可从您网站上的任何页面读取,请这样做。

$.cookie('the_cookie', 'the_value', { path: '/' });

另外,请注意我使用的是 , 而不是 :

关于javascript - GetCookie 返回 NULL,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10687746/

相关文章:

javascript - 阻止移动网络代理注入(inject) JavaScript

javascript - AngularJS 中的表单未验证

jquery - 隐藏消息或淡出警报消息

jQueryUI 可排序、可拖动恢复事件

javascript - 在 Typescript 中向其添加函数之前,如何将变量声明为空对象?

javascript - if 语句内的 for 循环不会运行,我不知道为什么

javascript - jQuery Datepicker 将结束日期限制为一周而不超过前一天

javascript - 在单击函数条件语句中调用时,函数值未定义

jquery - 用HTML5和Canvas画出网站效果

javascript - 在javascript中声明一个变量并在html中使用