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 ...
随机推荐
- WEB 实时推送技术的总结
前言 随着 Web 的发展,用户对于 Web 的实时推送要求也越来越高 ,比如,工业运行监控.Web 在线通讯.即时报价系统.在线游戏等,都需要将后台发生的变化主动地.实时地传送到浏览器端,而不需要用 ...
- 详解Vue Native
译者按: 一家叫GeekyAnts的印度公司开发了Vue Native,基于React Native实现. 原文: Introducing Vue Native 译者: Fundebug 为了保证可读 ...
- Hacking Box Droopy: v0.2
概述: 目标:get flag 下载链接: https://www.vulnhub.com/entry/droopy-v02,143/ 工具: kail linux 开工 1)扫描开道: # netd ...
- 亿级流量场景下,大型缓存架构设计实现【1】---redis篇
*****************开篇介绍**************** -------------------------------------------------------------- ...
- python 生成图形验证码
文章链接:https://mp.weixin.qq.com/s/LYUBRNallHcjnhJb1R3ZBg 日常在网站使用过程中经常遇到图形验证,今天准备自己做个图形验证码,这算是个简单的功能,也适 ...
- 扩展1000!(n!)的尾数零的个数
#include <stdio.h> #include <malloc.h> //计算1000!尾数零的个数 //扩展n!的尾数零的个数 //2^a * 5^b //obvio ...
- Python模块time、datetime
模块: 模块是一系列常用功能的集合体,一个py文件就是一个模块. 一.模块的作用: 1.从文件级别组织程序,方便管理,随着程序的发展,功能越来越多,我们通常将程序分成一个个py文件,这样做程序的结构更 ...
- oracle nvl2函数
nvl2(v1, v2, v3) 定义:如果v1为空,返回v3: 不为空,返回v2 nvl2要求v2,v3的类型一致,不一致会发生类型转换.问题:最终返回值类型是v2的类型还是v3的类型? 看题目:n ...
- Linux之Samba部署
1.Samba介绍 Samba 是在 Linux 和 UNIX 系统上实现 SMB 协议的一个免费软件,由服务器及客户端程序构成,SMB(Server Messages Block,信息服务块)是一种 ...
- SQLServer之修改PRIMARY KEY
使用SSMS数据库管理工具修改PRIMARY KEY 1.连接数据库,选择数据表->右键点击->选择设计(或者展开键,选择要修改的键,右键点击,选择修改,后面步骤相同). 2.选择要修改的 ...