VUE浏览器储存封装
import {isFunction, extend} from 'lodash'
const _originStorage = function () {
var pluses = /\+/g
function encode (s) {
return _cookie.raw ? s : encodeURIComponent(s)
}
function decode (s) {
return _cookie.raw ? s : decodeURIComponent(s)
}
function stringifyCookieValue (value) {
return encode(_cookie.json ? JSON.stringify(value) : String(value))
}
function parseCookieValue (s) {
if (s.indexOf('"') === 0) {
s = s.slice(1, -1).replace(/\\"/g, '"').replace(/\\\\/g, '\\')
}
try {
s = decodeURIComponent(s.replace(pluses, ' '))
return _cookie.json ? JSON.parse(s) : s
} catch (e) {}
}
function read (s, converter) {
var value = _cookie.raw ? s : parseCookieValue(s)
return isFunction(converter) ? converter(value) : value
}
var _cookie = function (key, value, options) {
// Write
if (arguments.length > 1 && !isFunction(value)) {
options = extend({}, _cookie.defaults, options)
if (typeof options.expires === 'number') {
var days = options.expires
var t = options.expires = new Date()
t.setMilliseconds(t.getMilliseconds() + days * 864e+5)
}
return (document.cookie = [
encode(key), '=', stringifyCookieValue(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(''))
}
var result = key ? undefined : {}
var cookies = document.cookie ? document.cookie.split('; ') : []
var i = 0
var l = cookies.length
for (; i < l; i++) {
let parts = cookies[i].split('=')
let name = decode(parts.shift())
let cookie = parts.join('=')
if (key === name) {
result = read(cookie, value)
break
}
if (!key && (cookie = read(cookie)) !== undefined) {
result[name] = cookie
}
}
return result
}
// originStorage
return (function () {
var cookieKeyPrefix = '__localStorage__'
var supportLocalStorage = true
try {
window.localStorage.setItem('__test__', 1)
window.localStorage.getItem('__test__')
window.localStorage.removeItem('__test__')
} catch (e) {
supportLocalStorage = false
}
if (supportLocalStorage) {
return {
get: function (key) {
return window.localStorage.getItem(key)
},
set: function (key, value) {
return window.localStorage.setItem(key, value)
},
clear: function () {
return window.localStorage.clear()
},
remove: function (key) {
return window.localStorage.removeItem(key)
}
}
} else {
return {
get: function (key) {
return _cookie(cookieKeyPrefix + key)
},
set: function (key, value) {
return _cookie(cookieKeyPrefix + key, value, {
expires: 365
})
},
clear: function () {
var cookies = document.cookie.split(';')
for (var i = 0; i < cookies.length; i++) {
var key = cookies[i].split('=')[0]
if (key.indexOf(cookieKeyPrefix) === 0) {
_cookie(key, '', {
expires: -1
})
}
}
},
remove: function (key) {
return _cookie(cookieKeyPrefix + key, '', {
expires: -1
})
}
}
}
})()
}
// export default () => {
const _localStorage = function () {
const originStorage = _originStorage()
this.defaultOption = {
maxAge: 0 // ms
}
this.get = function (k) {
var self = this
var a = originStorage.get(k)
var _return
try {
var json = JSON.parse(a)
var expiresTimestamp = json.e
if (expiresTimestamp && Date.now() > expiresTimestamp) {
_return = undefined
self.remove(k)
} else {
_return = json.a
}
} catch (e) {
_return = undefined
}
return _return
}
this.set = function (k, v, option) {
option = extend(true, extend({}, this.defaultOption), option)
var o = {
a: v,
e: option.maxAge > 0 ? (Date.now() + option.maxAge) : 0
}
originStorage.set(k, typeof o === 'string' ? o : JSON.stringify(o))
}
this.clear = function () {
return originStorage.clear()
}
this.remove = function (k) {
return originStorage.remove(k)
}
}
export default new _localStorage()
挂载
// localStorage plugin
import localStorage from '@/common/localstorage'
function plugin (Vue) {
if (plugin.installed) {
return
}
Vue.localStorage = localStorage
Object.defineProperties(Vue.prototype, {
$localStorage: {
get () {
return localStorage
}
}
})
}
if (typeof window !== 'undefined' && window.Vue) {
window.Vue.use(plugin)
}
export default plugin
引入import LocalStorage from '@/plugin/localStorage';
Vue.use(LocalStorage);
VUE浏览器储存封装的更多相关文章
- vue2.0 如何自定义组件(vue组件的封装)
一.前言 之前的博客聊过 vue2.0和react的技术选型:聊过vue的axios封装和vuex使用.今天简单聊聊 vue 组件的封装. vue 的ui框架现在是很多的,但是鉴于移动设备的复杂性,兼 ...
- Vue之优化封装请求方法
Vue之优化封装请求方法 对于代码中的请求操作 1.接口请求可能需要重用 2.实际工作中,接口非常容易变动, 改起来很麻烦! 我们建议的做法是把所有的请求都封装成函数然后统一的>###组织到模块 ...
- vue自定义插件封装,实现简易的elementUi的Message和MessageBox
vue自定义插件封装示例 1.实现message插件封装(类似简易版的elementUi的message) message组件 <template> <transition ...
- 实例PK(Vue服务端渲染 VS Vue浏览器端渲染)
Vue 2.0 开始支持服务端渲染的功能,所以本文章也是基于vue 2.0以上版本.网上对于服务端渲染的资料还是比较少,最经典的莫过于Vue作者尤雨溪大神的 vue-hacker-news.本人在公司 ...
- Vue服务端渲染和Vue浏览器端渲染的性能对比
Vue 2.0 开始支持服务端渲染的功能,所以本文章也是基于vue 2.0以上版本.网上对于服务端渲染的资料还是比较少,最经典的莫过于Vue作者尤雨溪大神的 vue-hacker-news.本人在公司 ...
- Vue服务端渲染 VS Vue浏览器端渲染)
Vue 2.0 开始支持服务端渲染的功能,所以本文章也是基于vue 2.0以上版本.网上对于服务端渲染的资料还是比较少,最经典的莫过于Vue作者尤雨溪大神的 vue-hacker-news.本人在公司 ...
- vue项目-axios封装、easy-mock使用
vue全家桶概括下来就是 项目构建工具(vue-cli) 路由(vue-router) 状态管理(vuex) http请求工具 vue有自己的http请求工具插件vue-resource,但是vue2 ...
- android利用WebView实现浏览器的封装
android提供了封装浏览器的接口,可以让开发者利用自己的view显示网页内容.今天又实现研究了一下,利用WebView显示浏览器内容,还可以利用 WebViewClient显示自己需要的内容. 参 ...
- 原生JS跨浏览器事件封装处理
引子:用javascript给元素绑定事件,我们可以用addEventListener这个方法,然而这个方法有兼容问题,比如在IE浏览器上面就无效,在IE上面要用attachEvent这个方法 一.a ...
随机推荐
- Java开发笔记(三十)大小数BigDecimal
前面介绍的BigInteger只能表达任意整数,但不能表达小数,要想表达任意小数,还需专门的大小数类型BigDecimal.如果说设计BigInteger的目的是替代int和long类型,那么设计Bi ...
- Java开发笔记(六十一)Lambda表达式
前面介绍了匿名内部类的简单用法,通过在sort方法中运用匿名内部类,不但能够简化代码数量,还能保持业务代码的连续性.只是匿名内部类的结构仍显啰嗦,虽然它省去了内部类的名称,但是花括号里面的方法定义代码 ...
- 分析解剖微服务系列(二)-SOA和微服务异同
微服务架构模式成熟之前,软件领域讨论的比较多的是SOA的架构模式.SOA早在1996年就由Gartner提出,作为面向服务的架构模式,SOA的理念是对于复杂的企业IT系统,按照不同的.可重用的粒度划分 ...
- Dynamics 365权限变化大部署后需要注意什么?
本人微信公众号:微软动态CRM专家罗勇 ,回复292或者20190110可方便获取本文,同时可以在第一间得到我发布的最新博文信息,follow me!我的网站是 www.luoyong.me . 如果 ...
- 国人如此浮躁为哪般? --- 我看2018年度AI圈八大造假事件华人独占6件
国人如此浮躁为哪般? --- 我看2018年度AI圈八大造假事件华人独占6件 人工智能在2018年发展很快,取得了很多成绩:很多新的产品,框架,软硬件系统,层出不穷:以七巨头为首的业界头部企业也取得 ...
- Python进阶之面向对象编程
面向对象编程——Object Oriented Programming,简称OOP,是一种程序设计思想.OOP把对象作为程序的基本单元,一个对象包含了数据和操作数据的函数. 面向过程的程序设计把计算机 ...
- 36.Odoo产品分析 (四) – 工具板块(6) – 午餐管理(2)
查看Odoo产品分析系列--目录 接上一篇Odoo产品分析 (四) – 工具板块(6) – 午餐管理(1) 4 查看订单 点击"之前的订单",可以看到刚才的订单信息: 点击右边的 ...
- java线程介绍
文章讲解要点 1.线程创建几种方式2.线程常见设置方法,包括优先级.优先级休眠.停止等3.多线程间的数据交互与锁机制4.项目源码下载 线程介绍.png 一.线程创建方式 常见的线程创建方法以下三种 ...
- Linux压缩打包tar命令总结
命令简介 在Linux系统的维护.管理中,tar命令是一个使用频率很高的命令,tar命令的功能主要是将众多文件打包成一个tar文件并压缩,并且能保持文件的权限属性.tar其实最开始是用来做磁带 ...
- ffmpeg相关函数整理
1.av_read_frame() 该函数用于读取具体的音/视频帧数据,从流中读取数据帧到 AVPacket,AVPacket保存仍然是未解码的数据 int av_read_frame(AVForma ...