当前位置 主页 > 网站技术 > 代码类 >

    jQuery利用cookie 实现本地收藏功能(不重复无需多次命名)

    栏目:代码类 时间:2019-11-07 18:07

    1、cookie是什么:

    ①、cookie 是存储于访问者计算机中的变量。每当一台计算机通过浏览器来访问某个页面时,那么就可以通过 JavaScript 来创建和读取 cookie。

      ②、实际上 cookie 是存于用户硬盘的一个文件,这个文件通常对应于一个域名,当浏览器再次访问这个域名时,便使这个cookie可用。因此,cookie可以跨越一个域名下的多个网页,但不能跨越多个域名使用。

      ③、不同浏览器对 cookie 的实现也不一样。即保存在一个浏览器中的 cookie 到另外一个浏览器是 不能获取的。

    PS:cookie 和 session 都能保存计算机中的变量,但是 session 是运行在服务器端的,而客户端我们只能通过 cookie 来读取和创建变量。

    2、cookie的作用:

     ①、用户在第一次登录某个网站时,要输入用户名密码,如果觉得很麻烦,下次登录时不想输入了,那么就在第一次登录时将登录信息存放在 cookie 中。下次登录时我们就可以直接获取 cookie 中的用户名密码来进行登录。
    PS:虽然 浏览器将信息保存在 cookie 中是加密了,但是可能还是会造成不安全的信息泄露

      ②、类似于购物车性质的功能,第一次用户将某些商品放入购物车了,但是临时有事,将电脑关闭了,下次再次进入此网站,我们可以通过读取 cookie 中的信息,恢复购物车中的物品。
    PS:实际操作中,这种方法很少用了,基本上都是将这些信息存储在数据库中。然后通过查询数据库的信息来恢复购物车里的物品

      ③、页面之间的传值。在实际开发中,我们往往会通过一个页面跳转到另外一个页面。后端服务器我们可以通过数据库,session 等来传递页面所需要的值。但是在浏览器端,我们可以将数据保存在 cookie 中,然后在另外页面再去获取 cookie 中的数据。

    PS:这里要注意 cookie 的时效性,不然会造成获取 cookie 中数据的混乱。

    正文开始,下面通过代码给大家介绍jq cookie 本地收藏功能,

    JS核心部分

    说明:用split(',')分隔字符串转换数组数组,把上一次收藏的id 和这一次的收藏用 + “,”+ 当前id 来存入,到时候用split() 方法 转换成数组即可。

    <script type="text/javascript">
     $(function(){
     var arr = $.cookie("attractionsid").split(',');
     console.log($.cookie());
     for (var i = 0; i < arr.length; i++) {
     if(parseInt(arr[i]) == parseInt( 请填入ID值 )){
     //判断是否收藏过,收藏过亮图标
     $('#shoucang2').removeClass('hide');
     $('#shoucang1').addClass('hide');
     break;
     }
     };
     $("#shoucang").click(function(event) {
     var judge = true;
     console.log(arr)
     for (var i = 0; i < arr.length; i++) {
     if(parseInt(arr[i]) == parseInt(请填入ID值)){
      arr.splice(i,1);
      $.cookie("attractionsid", arr, { expires: 361});
      console.log('取消收藏');
      $('#shoucang2').addClass('hide');
      $('#shoucang1').removeClass('hide');
      judge = false;
      break;
     }
     };
     if(judge){
     $.cookie("attractionsid", $.cookie("attractionsid") + ","+"请填入ID值", { expires: 361});
     console.log('收藏成功');
     $('#shoucang2').removeClass('hide');
     $('#shoucang1').addClass('hide');
     }
     });
     })
    </script>

    总结

    以上所述是小编给大家介绍的jQuery利用cookie 实现本地收藏功能,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对IIS7站长之家网站的支持!