如何实现一个简易版的vuex持久化工具-创新互联

背景

为丰润等地区用户提供了全套网页设计制作服务,及丰润网站建设行业解决方案。主营业务为网站设计制作、成都网站设计、丰润网站设计,以传统方式定制建设网站,并提供域名空间备案等一条龙服务,秉承以专业、用心的态度为用户提供真诚的服务。我们深信只要达到每一位用户的要求,就会得到认可,从而选择与我们长期合作。这样,我们也可以走得更远!

最近用uni-app开发小程序项目时,部分需要持久化的内容没法像其他vuex中的state那样调用,所以想着自己实现一下类似vuex-persistedstate插件的功能,貌似代码量也不会很大

初步思路


首先想到的实现方式自然是vue的watcher模式。对需要持久化的内容进行劫持,当内容改变时,执行持久化的方法。
先弄个dep和observer,直接observer需要持久化的state,并传入get和set时的回调:

function dep(obj, key, options) {
 let data = obj[key]
 Object.defineProperty(obj, key, {
  configurable: true,
  get() {
   options.get()
   return data
  },
  set(val) {
   if (val === data) return
   data = val
   if(getType(data)==='object') observer(data)
   options.set()
  }
 })
}
function observer(obj, options) {
 if (getType(obj) !== 'object') throw ('参数需为object')
 Object.keys(obj).forEach(key => {
  dep(obj, key, options)
  if(getType(obj[key]) === 'object') {
   observer(obj[key], options)
  }
 })
}

网站题目:如何实现一个简易版的vuex持久化工具-创新互联
文章来源:http://hxwzsj.com/article/ppoji.html

其他资讯

Copyright © 2025 青羊区翔捷宏鑫字牌设计制作工作室(个体工商户) All Rights Reserved 蜀ICP备2025123194号-14
友情链接: 泸州网站建设 网站制作 成都网站制作 重庆网站制作 定制级高端网站建设 成都网站设计 网站建设方案 手机网站制作 做网站设计 网站建设方案 成都h5网站建设 成都网站建设 商城网站建设 手机网站制作 企业网站设计 梓潼网站设计 成都网站建设 成都网站设计 外贸网站建设 企业网站设计 成都企业网站设计 成都品牌网站建设