如何使用jQuery操作Cookies方法解析


Posted in jQuery onSeptember 08, 2020

Cookies

定义:让网站服务器把少量数据储存到客户端的硬盘或内存,从客户端的硬盘读取数据的一种技术;

下载与引入:jquery.cookie.js基于jquery;先引入jquery,再引入:jquery.cookie.js;下载:http://plugins.jquery.com/cookie/

<script type="text/javascript" src="js/jquery.min.js">
</script><script type="text/javascript" src="js/jquery.cookie.js"></script>

jquery.cookie.js代码的内容并不多,可以直接拷贝一下

jQuery.cookie = function (key, value, options) {

  // key and value given, set cookie...
  if (arguments.length > 1 && (value === null || typeof value !== "object")) {
    options = jQuery.extend({}, options);

    if (value === null) {
      options.expires = -1;
    }

    if (typeof options.expires === 'number') {
      var days = options.expires, t = options.expires = new Date();
      t.setDate(t.getDate() + days);
    }

    return (document.cookie = [
      encodeURIComponent(key), '=',
      options.raw ? String(value) : encodeURIComponent(String(value)),
      options.expires ? '; expires=' + options.expires.toUTCString() : '', // use expires attribute, max-age is not supported by IE
      options.path ? '; path=' + options.path : '',
      options.domain ? '; domain=' + options.domain : '',
      options.secure ? '; secure' : ''
    ].join(''));
  }

  // key and possibly options given, get cookie...
  options = value || {};
  var result, decode = options.raw ? function (s) { return s; } : decodeURIComponent;
  return (result = new RegExp('(?:^|; )' + encodeURIComponent(key) + '=([^;]*)').exec(document.cookie)) ? decode(result[1]) : null;
};

1.添加一个"会话cookie"

$.cookie('the_cookie', 'the_value');

这里没有指明 cookie有效时间,所创建的cookie有效期默认到用户关闭浏览器为止,所以被称为 “会话cookie(session cookie)”。

2.创建一个cookie并设置有效时间为 7天

$.cookie('the_cookie', 'the_value', { expires: 7 });

这里指明了cookie有效时间,所创建的cookie被称为“持久 cookie (persistent cookie)”。注意单位是:天;

PS:这里好像是有问题啊,试了半天,发现jquery设置的cookie过期时间关闭浏览器就失效,https://www.cnblogs.com/acm-bingzi/p/jquery_cookie_expire.html

3.创建一个cookie并设置 cookie的有效路径

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

在默认情况下,只有设置 cookie的网页才能读取该 cookie。如果想让一个页面读取另一个页面设置的cookie,必须设置cookie的路径。cookie的路径用于设置能够读取 cookie的顶级目录。将这个路径设置为网站的根目录,可以让所有网页都能互相读取 cookie (一般不要这样设置,防止出现冲突)。

4.读取cookie

$.cookie('the_cookie');

5.删除cookie

$.cookie('the_cookie', null); //通过传递null作为cookie的值即可

6.可选参数

$.cookie('the_cookie','the_value',{

expires:7,

path:'/',

domain:'jquery.com',

secure:true
}) 

  • expires:(Number|Date)有效期;设置一个整数时,单位是天;也可以设置一个日期对象作为Cookie的过期日期;
  • path:(String)创建该Cookie的页面路径;
  • domain:(String)创建该Cookie的页面域名;
  • secure:(Booblean)如果设为true,那么此Cookie的传输会要求一个安全协议,例如:HTTPS;

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

jQuery 相关文章推荐
Jquery获取radio选中的值
May 05 jQuery
jQuery extend()详解及简单实例
May 06 jQuery
jQuery Validate 校验多个相同name的方法
May 18 jQuery
jQuery访问浏览器本地存储cookie、localStorage和sessionStorage的基本用法
Oct 20 jQuery
jQuery中的$是什么意思及 $. 和 $().的区别
Apr 20 jQuery
关于jquery layui弹出层的使用方法
Apr 21 jQuery
jQuery 点击获取验证码按钮及倒计时功能
Sep 20 jQuery
JS/jQuery实现获取时间的方法及常用类完整示例
Mar 07 jQuery
jQuery实现条件搜索查询、实时取值及升降序排序的方法分析
May 04 jQuery
jquery+php后台实现省市区联动功能示例
May 23 jQuery
jquery 回调操作实例分析【回调成功与回调失败的情况】
Sep 27 jQuery
IDEA配置jQuery, $符号不再显示黄色波浪线的问题
Oct 09 jQuery
jQuery实现简单三级联动效果
Sep 05 #jQuery
如何基于jQuery实现五角星评分
Sep 02 #jQuery
jQuery中getJSON跨域原理的深入讲解
Sep 02 #jQuery
Jquery $.map使用方法实例详解
Sep 01 #jQuery
JQuery基于FormData异步提交数据文件
Sep 01 #jQuery
JQuery使用数组遍历跳出each循环
Sep 01 #jQuery
JS JQuery获取data-*属性值方法解析
Sep 01 #jQuery
You might like
php面向对象全攻略 (六)__set() __get() __isset() __unset()的用法
2009/09/30 PHP
关于js和php对url编码的处理方法
2014/03/04 PHP
Yii2结合Workerman的websocket示例详解
2018/09/10 PHP
DHTML 中的绝对定位
2006/11/26 Javascript
js控制的回到页面顶端goTop的代码实现
2013/03/20 Javascript
ext中store.load跟store.reload的区别示例介绍
2014/06/17 Javascript
jQuery+canvas实现的球体平抛及颜色动态变换效果
2016/01/28 Javascript
jquery实现全选功能效果的实现代码
2016/05/05 Javascript
express文件上传中间件Multer详解
2016/10/24 Javascript
jq stop()和:is(:animated)的用法及区别(详解)
2017/02/12 Javascript
webpack配置文件和常用配置项介绍
2017/04/28 Javascript
详解微信小程序审核不通过的解决方法
2018/01/17 Javascript
zTree 树插件实现全国五级地区点击后加载的示例
2018/02/05 Javascript
vue form check 表单验证的实现代码
2018/12/09 Javascript
JavaScript使用Math.random()生成简单的验证码
2019/01/21 Javascript
vue路由--网站导航功能详解
2019/03/29 Javascript
[50:17]Newbee vs Serenity 2018国际邀请赛小组赛BO2 第二场 8.17
2018/08/18 DOTA
django之常用命令详解
2016/06/30 Python
Python实现的读写json文件功能示例
2018/06/05 Python
matplotlib给子图添加图例的方法
2018/08/03 Python
Python爬虫beautifulsoup4常用的解析方法总结
2019/02/25 Python
python3使用matplotlib绘制散点图
2019/03/19 Python
django orm模块中的 is_delete用法
2020/05/20 Python
Python爬虫之Spider类用法简单介绍
2020/08/04 Python
python利用google翻译方法实例(翻译字幕文件)
2020/09/21 Python
Python远程linux执行命令实现
2020/11/11 Python
css3实现3D文本悬停改变效果的示例代码
2019/01/16 HTML / CSS
GE设备配件:GE Appliance Parts(家电零件、配件和滤水器)
2018/11/28 全球购物
用Python写一个for循环的例子
2016/07/19 面试题
九州传奇上机题
2014/07/10 面试题
入团者的自我评价分享
2013/12/02 职场文书
师说教学反思
2014/02/07 职场文书
留学推荐信中文范文
2015/03/26 职场文书
教你如何用python开发一款数字推盘小游戏
2021/04/14 Python
总结Pyinstaller打包的高级用法
2021/06/28 Python
2021年国漫热度排行前十,完美世界上榜,第四是美国动画作品
2022/03/18 国漫