Java自学者论坛

 找回密码
 立即注册

手机号码,快捷登录

恭喜Java自学者论坛(https://www.javazxz.com)已经为数万Java学习者服务超过8年了!积累会员资料超过10000G+
成为本站VIP会员,下载本站10000G+会员资源,会员资料板块,购买链接:点击进入购买VIP会员

JAVA高级面试进阶训练营视频教程

Java架构师系统进阶VIP课程

分布式高可用全栈开发微服务教程Go语言视频零基础入门到精通Java架构师3期(课件+源码)
Java开发全终端实战租房项目视频教程SpringBoot2.X入门到高级使用教程大数据培训第六期全套视频教程深度学习(CNN RNN GAN)算法原理Java亿级流量电商系统视频教程
互联网架构师视频教程年薪50万Spark2.0从入门到精通年薪50万!人工智能学习路线教程年薪50万大数据入门到精通学习路线年薪50万机器学习入门到精通教程
仿小米商城类app和小程序视频教程深度学习数据分析基础到实战最新黑马javaEE2.1就业课程从 0到JVM实战高手教程MySQL入门到精通教程
查看: 637|回复: 0

页面刷新vuex数据消失问题解决方案 之 vuex中间件

[复制链接]
  • TA的每日心情
    奋斗
    2024-11-24 15:47
  • 签到天数: 804 天

    [LV.10]以坛为家III

    2053

    主题

    2111

    帖子

    72万

    积分

    管理员

    Rank: 9Rank: 9Rank: 9

    积分
    726782
    发表于 2021-7-1 22:51:35 | 显示全部楼层 |阅读模式

    之前我写了一篇用ES6 Proxy方案解决数据同步的文章 页面刷新vuex数据消失问题解决方案.

    今天和同事沟通这个vuex数据还原问题,我说我的方法很奇异。聊着聊着,同事咋不用  store.subscribe , 当时还有点觉得不可能,仔细再去看vuex官方文档。

    这个还真的是可行,但当然也是存在不方便的地方的。

    此方案现在已经应用我基于vue开发的音乐web app VBOX 上,欢迎大家给star.

    基本方案和步骤如下

    1. 简单的按照键复制对象

    2. localStorage存储的封装

    3. vuex插件编写

    4. localStorage的数据还原和初始化 Vuex.Store

     

    第一:简单的按照键复制对象

    复制代码
    /**
     * 数据简单复制
     * @param {*} source 
     * @param {*} keys 
     */
    const copy = function (source, keys = []) {
      if (!source) {
        return source
      }
      let d = Object.create(null)
      keys.forEach(k => { d[k] = source[k] })
      return d
    }
    
    export {
      copy
    }
    复制代码

     

    第二:localStorage的简单封装

    复制代码
    const ls = window.localStorage
    // https://github.com/tsironis/lockr
    export default {
      getItem(key) {
        try {
          return JSON.parse(ls.getItem(key))
        } catch (err) {
          return null
        }
      },
      setItem(key, val) {
        ls.setItem(key, JSON.stringify(val))
      },
      clear() {
        ls.clear()
      },
      keys() {
        return ls.keys()
      },
      removeItem(key) {
        ls.removeItem(key)
      }
    }
    复制代码

    第三:vuex插件

     主要是一个lsKey,存到localStorage的key,

    另外一个是 mutation白名单,白名单内的触发不会触发数据同步

    实际上这里是存在一定问题的,这里适用模块后的store

      (1) 无法快速有效便捷的定位什么时候该触发同步

      

    复制代码
    import ls from '../utils/LStorage'
    import { copy } from '../utils/utils'
    
    export const createLSPlugin = function (lsKey, mappings, whitelist = []) {
      let k = lsKey || 'lsKey'
      return store => {
        store.subscribe((mutation, state) => {
          if (whitelist.findIndex(m => m === mutation.type) < 0) {
            let cd = Object.create(null)
            Object.keys(state).forEach(k => {
              if (mappings[k]) {
                cd[k] = copy(state[k], mappings[k])
              }
            })
            ls.setItem(k, cd)
          }
        })
      }
    }
    复制代码

      

     

    第四:初始化Vuex.Store

    主要是从localStore里面还原数据合并到state里面,如果state没有分模块还是比较简单的。

    复制代码
    import Vue from 'vue'
    import Vuex from 'vuex'
    
    import playing from './playing'
    import player from './player'
    import searchHistory from './searchHistory'
    
    import { createLSPlugin } from '../plugin/syncls'
    import ls from '../utils/LStorage'
    
    const LS_KEY = 'vbox'
    
    const lsData = ls.getItem(LS_KEY)
    let mapping = {
      playing: ['list', 'current'],
      player: ['mode'],
      searchHistory: ['list']
    
    }
    let mWhiteList = ['player/timeUpdate', 'player/setState']
    if (lsData) {
      let { playing: ls_playing, player: ls_player, searchHistory: ls_searchHistory } = lsData
      Object.assign(playing, { state: ls_playing })
      Object.assign(player, { state: ls_player })
      Object.assign(searchHistory, { state: ls_searchHistory })
    }
    
    Vue.use(Vuex)
    const plugin = createLSPlugin(LS_KEY, mapping, mWhiteList)
    const store = new Vuex.Store({
      modules: {
        playing,
        player,
        searchHistory
      },
      plugins: [plugin]
    })
    
    export default store
    复制代码

     

     

    优点

    1. 代码简单,对代码改动不大

    2. 对原始的state没有额外干预

    缺点

    1. 触发存储条件不好控制

    2. 存储限制实现会相对复杂

    哎...今天够累的,签到来了1...
    回复

    使用道具 举报

    您需要登录后才可以回帖 登录 | 立即注册

    本版积分规则

    QQ|手机版|小黑屋|Java自学者论坛 ( 声明:本站文章及资料整理自互联网,用于Java自学者交流学习使用,对资料版权不负任何法律责任,若有侵权请及时联系客服屏蔽删除 )

    GMT+8, 2024-12-23 08:34 , Processed in 0.060281 second(s), 30 queries .

    Powered by Discuz! X3.4

    Copyright © 2001-2021, Tencent Cloud.

    快速回复 返回顶部 返回列表