轻量级JS Cookie插件js-cookie的使用方法


Posted in Javascript onMarch 22, 2018

Cookie是网站设计者放置在客户端的小文本文件,一般后台语言使用的比较多,可以实现用户个性化的一些需求。js-cookie插件是一个JS操作cookie的插件,源文件只有3.34 KB,非常轻量级。js-cookie也支持npm和Bower安装和管理。下面看看js-cookie的具体用法。

A simple, lightweight JavaScript API for handling cookies

Works in all browsers
Accepts any character
Heavily tested
No dependency
Unobtrusive JSON support
Supports AMD/CommonJS
RFC 6265 compliant
Useful Wiki
Enable custom encoding/decoding
~900 bytes gzipped!

引用方法:

1、引入js-cookie.js

1.直接饮用cdn:<script src="https://cdn.jsdelivr.net/npm/js-cookie@2/src/js.cookie.min.js"></script>

2.本地下载下来后:<script src="/path/to/js.cookie.js"></script>

3.模块化开发时: import Cookies from 'js-cookie'

2、js-cookie.js常用的API和方法

a、设置cookie

Cookies.set('name', 'value', { expires: 7, path: '' });//7天过期

Cookies.set('name', { foo: 'bar' });//设置一个json

b、读取cookie

Cookies.get('name');//获取cookie

Cookies.get(); #读取所有的cookie

c、删除cookie

Cookies.remove('name'); #删除cookie时必须是同一个路径。

下面是国外的介绍

Basic Usage

Create a cookie, valid across the entire site:

Cookies.set('name', 'value');

Create a cookie that expires 7 days from now, valid across the entire site:

Cookies.set('name', 'value', { expires: 7 });

Create an expiring cookie, valid to the path of the current page:

Cookies.set('name', 'value', { expires: 7, path: '' });

Read cookie:

Cookies.get('name'); // => 'value'
Cookies.get('nothing'); // => undefined

Read all visible cookies:

Cookies.get(); // => { name: 'value' }

Delete cookie:

Cookies.remove('name');

Delete a cookie valid to the path of the current page:

Cookies.set('name', 'value', { path: '' });
Cookies.remove('name'); // fail!
Cookies.remove('name', { path: '' }); // removed!

IMPORTANT! When deleting a cookie, you must pass the exact same path and domain attributes that were used to set the cookie, unless you're relying on the default attributes.

Note: Removing a nonexistent cookie does not raise any exception nor return any value.

Namespace conflicts

If there is any danger of a conflict with the namespace Cookies, the noConflict method will allow you to define a new namespace and preserve the original one. This is especially useful when running the script on third party sites e.g. as part of a widget or SDK.

// Assign the js-cookie api to a different variable and restore the original "window.Cookies"

var Cookies2 = Cookies.noConflict();
Cookies2.set('name', 'value');

Note: The .noConflict method is not necessary when using AMD or CommonJS, thus it is not exposed in those environments.

JSON

js-cookie provides unobtrusive JSON storage for cookies.

When creating a cookie you can pass an Array or Object Literal instead of a string in the value. If you do so, js-cookie will store the string representation of the object according to JSON.stringify:

Cookies.set('name', { foo: 'bar' });

When reading a cookie with the default Cookies.get api, you receive the string representation stored in the cookie:

Cookies.get('name'); // => '{"foo":"bar"}'
Cookies.get(); // => { name: '{"foo":"bar"}' }

When reading a cookie with the Cookies.getJSON api, you receive the parsed representation of the string stored in the cookie according to JSON.parse:

Cookies.getJSON('name'); // => { foo: 'bar' }
Cookies.getJSON(); // => { name: { foo: 'bar' } }

Note: To support IE6-7 (and IE 8 compatibility mode) you need to include the JSON-js polyfill: https://github.com/douglascrockford/JSON-js

更多的可以参考官方说明:

https://github.com/js-cookie/js-cookie

https://www.npmjs.com/package/js-cookie

Javascript 相关文章推荐
几行代码轻松搞定jquery实现flash8类似的连接效果
May 03 Javascript
js创建数据共享接口——简化框架之间相互传值
Oct 23 Javascript
用示例说明filter()与find()的用法以及children()与find()的区别分析
Apr 26 Javascript
详解基于angular-cli配置代理解决跨域请求问题
Jul 05 Javascript
IScroll那些事_当内容不足时下拉刷新的解决方法
Jul 18 Javascript
详解vue-cli之webpack3构建全面提速优化
Dec 25 Javascript
JavaScript实现微信红包算法及问题解决方法
Apr 26 Javascript
vue 解决循环引用组件报错的问题
Sep 06 Javascript
微信小程序传值以及获取值方法的详解
Apr 29 Javascript
Vue.js构建你的第一个包并在NPM上发布的方法步骤
May 01 Javascript
使用npm命令提示: 'npm' 不是内部或外部命令,也不是可运行的程序的处理方法
May 14 Javascript
利用 JavaScript 构建命令行应用
Nov 17 Javascript
浅谈Webpack 持久化缓存实践
Mar 22 #Javascript
深入浅析Vue.js中 computed和methods不同机制
Mar 22 #Javascript
Java设计中的Builder模式的介绍
Mar 22 #Javascript
使用vue-route 的 beforeEach 实现导航守卫(路由跳转前验证登录)功能
Mar 22 #Javascript
收集前端面试题之url、href、src
Mar 22 #Javascript
vue 的keep-alive缓存功能的实现
Mar 22 #Javascript
bootstrap中selectpicker下拉框使用方法实例
Mar 22 #Javascript
You might like
简单了解WordPress开发中update_option()函数的用法
2016/01/11 PHP
php基于单例模式封装mysql类完整实例
2016/10/18 PHP
PHP实现基于栈的后缀表达式求值功能
2017/11/10 PHP
求解开jscript.encode代码的asp函数
2007/02/28 Javascript
关于 byval 与 byref 的区别分析总结
2007/10/08 Javascript
扩展jQuery 键盘事件的几个基本方法
2009/10/30 Javascript
jQuery操作DOM之获取表单控件的值
2015/01/23 Javascript
JavaScript对HTML DOM使用EventListener进行操作
2015/10/21 Javascript
jQuery隐藏和显示效果实现
2016/04/06 Javascript
Bootstrap零基础入门教程(二)
2016/07/18 Javascript
Ajax的概述与实现过程
2016/11/18 Javascript
Node.js开发教程之基于OnceIO框架实现文件上传和验证功能
2016/11/30 Javascript
bootstrap timepicker在angular中取值并转化为时间戳
2017/06/13 Javascript
JS实现的base64加密解密操作示例
2018/04/18 Javascript
vue最简单的前后端交互示例详解
2018/10/11 Javascript
JavaScript中callee和caller的区别与用法实例分析
2019/06/28 Javascript
[57:53]Secret vs Pain 2018国际邀请赛小组赛BO2 第二场 8.17
2018/08/20 DOTA
win7 下搭建sublime的python开发环境的配置方法
2014/06/18 Python
python执行等待程序直到第二天零点的方法
2015/04/23 Python
python实现将英文单词表示的数字转换成阿拉伯数字的方法
2015/07/02 Python
python3.4用函数操作mysql5.7数据库
2017/06/23 Python
Android分包MultiDex策略详解
2017/10/30 Python
深入理解Python单元测试unittest的使用示例
2017/11/18 Python
Python基于动态规划算法解决01背包问题实例
2017/12/06 Python
对python中的logger模块全面讲解
2018/04/28 Python
numpy中的delete删除数组整行和整列的实例
2018/05/09 Python
python计算阶乘和的方法(1!+2!+3!+...+n!)
2019/02/01 Python
Python----数据预处理代码实例
2019/03/20 Python
Python+Tensorflow+CNN实现车牌识别的示例代码
2019/10/11 Python
Python如何合并多个字典或映射
2020/07/24 Python
python如何爬取网页中的文字
2020/07/28 Python
DJI大疆德国官方商城:大疆无人机
2018/09/01 全球购物
农村党支部书记四风问题个人对照检查材料
2014/09/21 职场文书
大学四年个人总结
2015/03/03 职场文书
幼儿园托班开学寄语(2015秋季)
2015/05/27 职场文书
python中mongodb包操作数据库
2022/04/19 Python