• 正在加载中...
  • js cookie

    请用一段简单的话描述该词条,马上添加摘要

    目录


    [color=#800000]function Setcookie(name, value) { //设置名称为name,值为value的Cookie
    var argc = setcookie.arguments.length;
        var argv = SetCookie.arguments;
        var path = (argc > 3) ? argv[3] : null;
        var domain = (argc > 4) ? argv[4] : null;
        var secure = (argc > 5) ? argv[5] : false;
        document.cookie = name + "=" + value + ((path == null) ? "" : ("; path=" + path)) + ((domain == null) ? "" : ("; domain=" + domain)) + ((secure == true) ? "; secure" : "");
    }
    function Deletecookie(name) { //删除名称为name的Cookie 
        var exp = new Date();
        exp.setTime(exp.getTime() - 1);
        var cval = GetCookie(name);
        document.cookie = name + "=" + cval + "; expires=" + exp.toGMTString();
    }
    function Clearcookie() { //清除COOKIE 
        var temp = document.cookie.split(";");
        var loop3;
        var ts;
        for (loop3 = 0; loop3; ) {
            ts = temp[loop3].split("=")[0];
            if (ts.indexOf("mycat") != -1) {
                DeleteCookie(ts);
            } //如果ts含“mycat”则执行清除 
        }
    }
    function getCookieVal(offset) { //取得项名称为offset的cookie值 
        var endstr = document.cookie.indexOf(";", offset);
        if (endstr == -1) {
            endstr = document.cookie.length;
        }
        return unescape(document.cookie.substring(offset, endstr));
    }
    function GetCookie(name) { //取得名称为name的cookie值 
        var arg = name + "=";
        var alen = arg.length;
        var clen = document.cookie.length;
        var i = 0;
        while (< clen) {
            var j = i + alen;
            if (document.cookie.substring(i, j) == arg) {
                return getCookieVal(j);
            }
            i = document.cookie.indexOf(" ", i) + 1;
            if (== 0) {
                break;
            }
        }
        return null;
    }
    [/color]
     
     
    ------------------------------------------------------------

    javascript操作cookie/js cookie 编辑

    问题:
        使得在访问页面的时候能够沿用上次的设置,或者在不同的页面间共享数据。比如用户在访问网站的时候设置了页面字体的大小,那么会希望下次访问的时候仍然能使用同样的设置进行浏览,而不用重复设置。
    解决方案:
        在用户浏览页面并进行设置时,将这些设置保存在cookie中,下次访问的时候读取cookie中的设置。
        参考下面的脚本:

        // utility function to retrieve an expiration data in proper format;
        function getExpDate(days, hours, minutes)
        {
            
    var expDate = new Date();
            
    if(typeof(days) == "number" && typeof(hours) == "number" && typeof(hours) == "number")
            {
                expDate.setDate(expDate.getDate() 
    + parseInt(days));
                expDate.setHours(expDate.getHours() 
    + parseInt(hours));
                expDate.setMinutes(expDate.getMinutes() 
    + parseInt(minutes));
                
    return expDate.toGMTString();
            }
        }

        
    //utility function called by getCookie()
        function getCookieVal(offset)
        {
            
    var endstr = document.cookie.indexOf(";", offset);
            
    if(endstr == -1)
            {
                endstr 
    = document.cookie.length;
            }
            
    return unescape(document.cookie.substring(offset, endstr));
        }

        
    // primary function to retrieve cookie by name
        function getCookie(name)
        {
            
    var arg = name + "=";
            
    var alen = arg.length;
            
    var clen = document.cookie.length;
            
    var i = 0;
            
    while(i < clen)
            {
                
    var j = i + alen;
                
    if (document.cookie.substring(i, j) == arg)
                {
                    
    return getCookieVal(j);
                }
                i 
    = document.cookie.indexOf(" ", i) + 1;
                
    if(i == 0break;
            }
            
    return;
        }

        
    // store cookie value with optional details as needed
        function setCookie(name, value, expires, path, domain, secure)
        {
            document.cookie 
    = name + "=" + escape(value) +
                ((expires) 
    ? "; expires=" + expires : ""+
                ((path) 
    ? "; path=" + path : ""+
                ((domain) 
    ? "; domain=" + domain : ""+
                ((secure) 
    ? "; secure" : "");
        }

        
    // remove the cookie by setting ancient expiration date
        function deleteCookie(name,path,domain)
        {
            
    if(getCookie(name))
            {
                document.cookie 
    = name + "=" +
                    ((path) 
    ? "; path=" + path : ""+
                    ((domain) 
    ? "; domain=" + domain : ""+
                    
    "; expires=Thu, 01-Jan-70 00:00:01 GMT";
            }
        }

        使用getCookie(name)函数来读取cookie中保存的值,参数name为cookie项的名称。如果该cookie项不存在则返回一个空字符串
        使用setCookie()函数来保存cookie项的值,其中第一、二两个参数分别为cookie项的名称和值。如果想为其设置一个过期时间,那么就需要设置第三个参数,这里需要通过getExpDate()获得一个正确格式的参数。
        最后,使用deleteCookie()来删除一个已存在的cookie项,实际上是通过让该项过期。
        cookie将数据保存在客户端。页面的脚本只能读取所在域和服务器的cookie值,如果域内有多个服务器,那么需要设置第五个参数,以指定服务器。浏览器的容量一般限定为每服务器20个name/value对,每个cookie项不超过4000个字符,更现实点,单个cookie项应少于2000字符,也就是说不要用cookie在客户端保存大容量数据。
        不同的浏览器保存cookie的方式也有所不同。IE为每个域的cookie建立一个文本文件,而Netscape则将所有的cookie存储在同一个文本文件中。
        注意:cookie存放在客户端,所以会受到浏览器设置的影响,比如用户可能会禁用cookie。要检测浏览器是否支持cookie,使用属性navigator.cookieEnabled来判断。


        参考: (oreilly) Java Script And Dhtml Cookbook.chm

    添加视频 | 添加图册相关影像

    开放分类 我来补充

    互动百科的词条(含所附图片)系由网友上传,如果涉嫌侵权,请与客服联系,我们将按照法律之相关规定及时进行处理。未经许可,禁止商业网站等复制、抓取本站内容;合理使用者,请注明来源于www.baike.com。

    登录后使用互动百科的服务,将会得到个性化的提示和帮助,还有机会和专业认证智愿者沟通。

    互动百科用户登录注册
    此词条还可添加  信息模块
    编辑摘要

    WIKI热度

    1. 编辑次数:2次 历史版本
    2. 参与编辑人数:1
    3. 最近更新时间:2007-05-10 18:49:32

    贡献光荣榜

    更多