解決vuex數(shù)據(jù)丟失問題
數(shù)據(jù)丟失的原因
vuex存儲的數(shù)據(jù)只是在頁面中,相當于全局變量,頁面刷新的時候vuex里的數(shù)據(jù)會重新初始化,導(dǎo)致數(shù)據(jù)丟失。
因為vuex里的數(shù)據(jù)是保存在運行內(nèi)存中的,當頁面刷新時,頁面會重新加載vue實例,vuex里面的數(shù)據(jù)就會被重新賦值。
方法1:使用第三方庫 vuex-persistedstate
npm install --save vuex-persistedstate
01 store / index.js 之 localStorage
- 注意點: vuex-persistedstate默認存儲在 localStorage之中,基本上不需要配置什么
import createPersistedState from "vuex-persistedstate"
const store =newVuex.Store({
state: {
cartList: [],
},
mutations: {},
actions: {},
// 當state中的值發(fā)生改變,此時localStorage中的vuex的值會同步把state中的所有值存儲起來,當頁面刷
新的時候,state的值會從localStorage自動獲取vuex的value值,賦值到state中
plugins: [createPersistedState()]
})
02 store / index.js 之 sessionStorage
import createPersistedState from "vuex-persistedstate"
const store = new Vuex.Store({
state: {},
mutations: {},
actions: {},
plugins: [createPersistedState({
storage:window.sessionStorage // 同localStorage相同,只是將vuex的所有值存儲到sessionStorage中
})]
})03 store / index.js 之 使用vuex-persistedstate指定需要持久化的state
import createPersistedState from "vuex-persistedstate"
const store = newVuex.Store({
?state: {
count: 0
},
?mutations: {},
?actions: {},
?plugins: [createPersistedState({
? storage:window.sessionStorage,
? reducer(val) ?{
? ? ? ? ?// 此時,當count發(fā)生改變的時候,就會調(diào)用此函數(shù),并且val的值為當前state對象,return的值為當前本地存儲的value值(本地存儲的key值為vuex)
? ? ? ? ?return {
? ? ? ? ? ? ?count: val.count,
? ?changeCount: 'aaa'
? ? ? ? ?}
? ? ?}
?})]
})方法2 把state的數(shù)據(jù)先緩存到localStorage之中,頁面刷新的時候,拿到數(shù)據(jù)寫入vuex
store / index.js
import Vue from 'vue';
import Vuex from 'vuex';
Vue.use(Vuex);
export default new Vuex.Store({
state: {
orderList: [],
menuList: []
},
mutations: {
orderList(s, d) {
s.orderList= d;
window.localStorage.setItem("list",jsON.stringify(s.orderList))
},
menuList(s, d) {
s.menuList = d;
window.localStorage.setItem("list",jsON.stringify(s.menuList))
},
}
})頁面刷新的時候
通過監(jiān)聽beforeunload事件來進行數(shù)據(jù)的localStorage存儲,beforeunload事件在頁面刷新時進行觸發(fā),具體做法是在App.vue的created()周期函數(shù)中下如下代碼
if (window.localStorage.getItem("list") ) {
this.$store.replaceState(Object.assign({}, this.$store.state,JSON.parse(window.localStorage.getItem("list"))))
}
window.addEventListener("beforeunload",()=>{
window.localStorage.setItem("list",JSON.stringify(this.$store.state))
})到此這篇關(guān)于解決vuex數(shù)據(jù)丟失問題的文章就介紹到這了,更多相關(guān)vuex 數(shù)據(jù)丟失內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- vuex刷新之后數(shù)據(jù)丟失,數(shù)據(jù)持久化,vuex-persistedstate問題
- vuex頁面刷新數(shù)據(jù)丟失問題的四種解決方式
- 解決vue頁面刷新vuex中state數(shù)據(jù)丟失的問題
- vuex結(jié)合session存儲數(shù)據(jù)解決頁面刷新數(shù)據(jù)丟失問題
- 關(guān)于vuex強刷數(shù)據(jù)丟失問題解析
- vuex頁面刷新導(dǎo)致數(shù)據(jù)丟失的解決方案
- vuex刷新后數(shù)據(jù)丟失的解決方法
- vuex存儲復(fù)雜參數(shù)(如對象數(shù)組等)刷新數(shù)據(jù)丟失的解決方法
- vuex頁面刷新后數(shù)據(jù)丟失的方法
相關(guān)文章
使用Vue如何寫一個雙向數(shù)據(jù)綁定(面試常見)
這篇文章主要介紹了使用Vue如何寫一個雙向數(shù)據(jù)綁定,在前端面試過程中經(jīng)常會問到,文中主要實現(xiàn)v-model,v-bind 和v-click三個命令,其他命令也可以自行補充。需要的朋友可以參考下2018-04-04
elementUI如何動態(tài)給el-tree添加子節(jié)點數(shù)據(jù)children詳解
element-ui 目前基本成為前端pc網(wǎng)頁端標準ui框架,下面這篇文章主要給大家介紹了關(guān)于elementUI如何動態(tài)給el-tree添加子節(jié)點數(shù)據(jù)children的相關(guān)資料,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下2022-11-11
詳解Jest結(jié)合Vue-test-utils使用的初步實踐
這篇文章主要介紹了詳解Jest結(jié)合Vue-test-utils使用的初步實踐,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2019-06-06
前端文件導(dǎo)出設(shè)置responseType為blob時遇到的問題及解決
這篇文章主要給大家介紹了關(guān)于前端文件導(dǎo)出設(shè)置responseType為blob時遇到的問題及解決方法,文中通過圖文介紹的非常詳細,對大家的學習或者工作具有一定的參考借鑒價值,需要的朋友可以參考下2023-09-09
vue如何通過image-conversion實現(xiàn)圖片壓縮詳解
在Vue項目中上傳大圖片時,可以通過image-conversion庫壓縮至指定大小,這篇文章主要介紹了vue如何通過image-conversion實現(xiàn)圖片壓縮的相關(guān)資料,文中通過代碼介紹的非常詳細,需要的朋友可以參考下2024-12-12
vue-resource調(diào)用promise取數(shù)據(jù)方式詳解
這篇文章主要介紹了vue-resource調(diào)用promise取數(shù)據(jù)方式詳解,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-07-07

