• vue刷新页面,数据不丢失


    在做vue项目的过程中有时候会遇到一个问题,就是进行F5页面刷新的时候,页面的数据会丢失,出现这个问题的原因是因为当用vuex做全局状态管理的时候,store中的数据是保存在运行内存中的,页面刷新时会重新加载vue实例,store中的数据就会被重新赋值,因此数据就丢失了,解决方式如下:

    方法1、利用localStorage/sessionStorage将数据储存在外部,做一个持久化储存,通过监听beforeunload事件来进行数据的localStorage存储,beforeunload事件在页面刷新时进行触发,具体做法是在App.vue的created()周期函数中下如下代码:

    export default {
       name: 'App',
       created () {    
           //在页面加载时读取localStorage里的状态信息
           if (window.localStorage.getItem('list')) {
              //this.$store.replaceState()替换 store 的根状态
              this.$store.replaceState(Object.assign({}, this.$store.state, 
              JSON.parse(window.localStorage.getItem('list'))))
          }
              //在页面刷新时将vuex里的信息保存到localStorage里
              window.addEventListener('beforeunload', () => {
              window.localStorage.setItem('list', JSON.stringify(this.$store.state))
          })
      }
    }    
    

     方法2:由此得知计算属性的结果会被缓存,也就是说在有缓存的情况下,computed会优先使用缓存,于是也可以在state数据相对应的页面这样写:

    computed:{
       orderList() {
           return this.$store.state.orderList
       }
    }
    

      

     

  • 相关阅读:
    实现分布式爬虫
    hadoop安装文档
    远程连接mysql和redis配置
    scrapy(2)
    10月10号动手动脑
    10月6日和动手动脑
    10月4日
    课程总结
    又学java的第一天
    第一节测试总结
  • 原文地址:https://www.cnblogs.com/mark21/p/14148352.html
Copyright © 2020-2023  润新知