zoukankan      html  css  js  c++  java
  • 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
       }
    }
    

      

     

  • 相关阅读:
    20201015-3 每周例行报告
    20201008-1 每周例行报告
    20200924-2 功能测试
    贺敬文2019102936-1总结
    20191114-1 每周例行报告
    20191107-1 每周例行报告
    20191031-1 每周例行报告
    每周例行报告
    20191017-1 每周例行报告
    每周例行报告
  • 原文地址:https://www.cnblogs.com/mark21/p/14148352.html
Copyright © 2011-2022 走看看