网站首页 > 基础教程 正文
1、前言:
在vue中如果想要操作cookie,除了使用之前我们自己封装好的操作cookie的方法之外,我们还可以使用vue-cookies插件,这是一个简单的Vue.js插件,专门用于在vue中处理浏览器的cookie操作,vue-cookies没有依赖关系,它可以独立存在,对vuejs友好。本篇博文就来介绍如何使用vue-cookies插件。
2.安装vue-cookies
npm install vue-cookies --save
3.引入vue-cookies
安装完毕后,我们需要在vue项目中明确引入vue-cookies。
import Vue from 'vue'
import VueCookies from 'vue-cookies'
Vue.use(VueCookies)
4.API
-设置全局配置,设置cookie过期时间和url
this.$cookies.config(expireTimes[,path]) // default: expireTimes = 1d , path=/
-设置一个cookie
this.$cookies.set(keyName, value[, expireTimes[, path[, domain[, secure]]]]) //return this
-获取一个cookie
this.$cookies.get(keyName) // return value
-删除一个cookie
this.$cookies.remove(keyName [, path [, domain]]) // return this
//例如:that.$cookies.remove("CHOOSE","/",'.xxx.com')
-检查某个 cookie name是否存在
this.$cookies.isKey(keyName) // return false or true
-获取所有 cookie name,以数组形式返回
this.$cookies.keys() // return a array
5.设置cookie过期时间
5.1全局设置
// 30天后过期
this.$cookies.config('30d')
this.$cookies.config(new Date(2019,03,13).toUTCString())
this.$cookies.config(60 * 60 * 24 * 30,'');
// window object
window.$cookies.config('30d')
5.2单个name设置
//不写过期时间,默认为1天过期
this.$cookies.set("user_session","25j_7Sl6xDq2Kc3ym0fmrSSk2xV2XkUkX")
// 1天过期,忽略大小写
this.$cookies.set("user_session","25j_7Sl6xDq2Kc3ym0fmrSSk2xV2XkUkX","1d")
this.$cookies.set("user_session","25j_7Sl6xDq2Kc3ym0fmrSSk2xV2XkUkX","1D")
// 以秒为单位,设置1天过去
this.$cookies.set("user_session","25j_7Sl6xDq2Kc3ym0fmrSSk2xV2XkUkX",60 * 60 * 24)
// 填写Date对象,明确指定过期时间
this.$cookies.set("user_session","25j_7Sl6xDq2Kc3ym0fmrSSk2xV2XkUkX", new Date(2017, 03, 12))
// 填写一个时间字符串,指定过期时间
this.$cookies.set("user_session","25j_7Sl6xDq2Kc3ym0fmrSSk2xV2XkUkX", "Sat, 13 Mar 2017 12:25:57 GMT")
//浏览器会话结束时过期
this.$cookies.set("default_unit_second","input_value","0");
//永不过期
this.$cookies.set("default_unit_second","input_value",-1);
5.3字符串单位形式设置
设置过期时间,输入字符串类型(字符均忽略大小写):
Unit | full name |
y | year |
m | month |
d | day |
h | hour |
min | minute |
s | second |
this.$cookies.set("token","GH1.1.1689020474.1484362313","60s"); // 60秒后过去
this.$cookies.set("token","GH1.1.1689020474.1484362313","30MIN"); // 30分钟后过去
this.$cookies.set("token","GH1.1.1689020474.1484362313","24d"); // 24天后过期
this.$cookies.set("token","GH1.1.1689020474.1484362313","4m"); // 4个月后过期
this.$cookies.set("token","GH1.1.1689020474.1484362313","16h"); // 16小时后过期
this.$cookies.set("token","GH1.1.1689020474.1484362313","3y"); // 3年后过期
6.其他操作
// set path
this.$cookies.set("use_path_argument","value","1d","/app");
// set domain
this.$cookies.set("use_path_argument","value",null, null, "domain.com");
// set secure
this.$cookies.set("use_path_argument","value",null, null, null,true);
**遇到的问题
1、this.$cookies.get('CHOOSEJWTTOKEN')为什么取不到值?
重点排除一下:如果cookie中设置了HttpOnly,那么通过js脚本将无法读取cookie信息。(这样能有效的防止XSS攻击,窃取cookie内容,但即便这样,也不建议将重要的信息存入cookie。)
//使用vue-cookies操作cookie的部分code
if(uni.getStorageSync('storage_token') == false){
if(this.$cookies.get('CHOOSEJWTTOKEN')){
uni.setStorageSync('storage_token',
this.$cookies.get('CHOOSEJWTTOKEN'));
}
}
//end
原文链接:https://www.jianshu.com/p/60c13168cc8f
- 上一篇: 「3mins」四条写JS模块的最佳实践
- 下一篇: HTTP系列之:HTTP中的cookies
猜你喜欢
- 2024-11-26 工作中,前端开发要看项目,怎么查看别人的js项目代码
- 2024-11-26 Cookie 在爬虫中的应用
- 2024-11-26 55个JS代码让你轻松当大神
- 2024-11-26 操作cookie
- 2024-11-26 9个原生js库助力前端开发,你都用过吗?
- 2024-11-26 Selenium4+Python3系列(七) Iframe、常见控件、JS、Cookie操作
- 2024-11-26 浅谈JavaScript的用处
- 2024-11-26 Web安全:XSS怎么实现?Cookie 劫持如此简单,你的网站安全吗?
- 2024-11-26 Cookies和Session的区别和理解
- 2024-11-26 cookie是什么?有什么用?cookie详解,一篇文章彻底搞懂cookie
- 最近发表
- 标签列表
-
- gitpush (61)
- pythonif (68)
- location.href (57)
- tail-f (57)
- pythonifelse (59)
- deletesql (62)
- c++模板 (62)
- css3动画 (57)
- c#event (59)
- linuxgzip (68)
- 字符串连接 (73)
- nginx配置文件详解 (61)
- html标签 (69)
- c++初始化列表 (64)
- exec命令 (59)
- canvasfilltext (58)
- mysqlinnodbmyisam区别 (63)
- arraylistadd (66)
- node教程 (59)
- console.table (62)
- c++time_t (58)
- phpcookie (58)
- mysqldatesub函数 (63)
- window10java环境变量设置 (66)
- c++虚函数和纯虚函数的区别 (66)