document.cookie.indexof的解释

代码:
function getCookie(c_name)
{

if(document.cookie.length > 0)

  {

    c_start = document.cookie.indexof(c_name + "=");

    if (c_start != -1)

       {

         c_start = c_start + c_name.length + 1;

         c_end = document.cookie.indexof(";", c_start);

         if (c_end == -1)

            {

              c_end = document.cookie.length;

             }

           return usescape(document.cookie.substring(c_start, c_end));

       }

   }

}

解释:

1、cookie保存在系统中的时候是“cookie名1 = cookie值; cookie名2 = cookie值”这样的方式来保存的。

2、document.cookie是返回包含所有cookie的字符串。

3、document.cookie.index(c_name + “=”)是取得这个cookie名在整个cookie中的位置。(加“=”号:取cookie名加上等于号的位置,比方整个cookie是”user=tony; passwd=user123”,这时候查找名为user的cookie值的时候,是查找”user=”的位置;如果不要等于号,就会找到其它位置的”user”,比如后面密码里面也有user字符,但并不是cookie中cookie名都是唯一的,所以加上等于号就不会出错。 )

4、c_start = c_start + c_name.length + 1是用先前取得的位置加上cookie名的长度再加1,就是把位置确定在这个cookie名的“=”符号的后面。

5、c_end = document.cookie.indexof(“;”, c_start)是从上一步的位置开始查找的,直到”;”的位置。

6、document.cookie.substring(c_start, c_end)就是取该cookie名的等号后面到分号前面的字符串,即对应的cookie的值。

====================

更好的读取Cookie

    写代码的时候,我们经常去使用一些开放的代码,尤其是读写cookie这种非常常用写起来又很无趣的功能。比如我就很喜欢去拷一些源码过来用,但也并不就是完美的,比如它提供的下面这段代码:

  function getCookie(c_name)

 {

 if (document.cookie.length>0)

    {

            c_start=document.cookie.indexOf(c_name + "=");

            if (c_start!=-1)

            { 

                    c_start=c_start + c_name.length+1;

                    c_end=document.cookie.indexOf(";",c_start);

                    if (c_end==-1) c_end=document.cookie.length;

                    return (document.cookie.substring(c_start,c_end));

            } 

    }

    return "";

}

上面这段代码是用来读取cookie的,但它存在一个问题,比如当cookie中同时存在这样两个字段“kuin=12345”和”uin=67890”时,如果

kuin在cookie中位于uin的前面,那么上面这段代码就无法读取uin的值了,因为它会误把kuin当作uin来读取。

那么如何修复呢,下面是优化后的代码:

    function getCookie(c_name)

{

    if (document.cookie.length>0)

    {

            var tmp_cookie = document.cookie,

            tmp_c1 = (tmp_cookie.indexOf(" "+c_name+"=")>0) ? (tmp_cookie.indexOf(" "+c_name+"=")+1) : 0,

            tmp_c2 = (tmp_cookie.indexOf(";"+c_name+"=")>0) ? (tmp_cookie.indexOf(";"+c_name+"=")+1) : 0,

            tmp_c3 = (tmp_cookie.indexOf(c_name+"=")==0) ? 0 : -1,

            c_start=tmp_c1 || tmp_c2 || tmp_c3;

            if (c_start!=-1)

            {

                    c_start=c_start + c_name.length+1;

                    var c_end=tmp_cookie.indexOf(";",c_start);

                    if (c_end==-1) c_end=tmp_cookie.length;

                    return (tmp_cookie.substring(c_start,c_end));

            }

    }

    return "";

}

补充:如果cookie中存在大量的值,我们就没有必要不断的使用getCookie()去读取了,更高效的方法是在第一次读取时直接将所有cookie解

析出来并存放在一个对象中,如下:

cookie = {

    uin: 12345,

    kuin: 59432,

    nick: flondon

};

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值