Vuex持久化插件(vuex-persistedstate)解決刷新數(shù)據(jù)消失的問題
頁面刷新后,想保存頁面未保存的數(shù)據(jù)。我們總是習慣于放在瀏覽器的sessionStorage和localStorage中。但是用了vue后,vuex便可以被應(yīng)用了。
vuex優(yōu)勢:相比sessionStorage,存儲數(shù)據(jù)更安全,sessionStorage可以在控制臺被看到。
vuex劣勢:在F5刷新頁面后,vuex會重新更新state,所以,存儲的數(shù)據(jù)會丟失。
vuex可以進行全局的狀態(tài)管理,但刷新后刷新后數(shù)據(jù)會消失,這是我們不愿意看到的。怎么解決呢,我們可以結(jié)合本地存儲做到數(shù)據(jù)持久化,也可以通過插件-vuex-persistedstate。
1.手動利用HTML5的本地存儲
方法
- vuex的state在localStorage或sessionStorage或其它存儲方式中取值
- 在mutations,定義的方法里對vuex的狀態(tài)操作的同時對存儲也做對應(yīng)的操作。這樣state就會和存儲一起存在并且與vuex同步
問題
最直觀的就是,手動寫比較麻煩。
2.利用vuex-persistedstate插件
插件的原理其實也是結(jié)合了存儲方式,只是統(tǒng)一的配置就不需要手動每次都寫存儲方法
使用方法
安裝
npm install vuex-persistedstate --save
引入及配置
在store下的index.js中
import createPersistedState from "vuex-persistedstate"
const store = new Vuex.Store({
// ...
plugins: [createPersistedState()]
})
默認存儲到localStorage
想要存儲到sessionStorage,配置如下
import createPersistedState from "vuex-persistedstate"
const store = new Vuex.Store({
// ...
plugins: [createPersistedState({
storage: window.sessionStorage
})]
})
想使用cookie同理
默認持久化所有state
指定需要持久化的state,配置如下
import createPersistedState from "vuex-persistedstate"
const store = new Vuex.Store({
// ...
plugins: [createPersistedState({
storage: window.sessionStorage,
reducer(val) {
return {
// 只儲存state中的assessmentData
assessmentData: val.assessmentData
}
}
})]
vuex引用多個插件的寫法
譬如:vuex提示的插件和持久化的插件一起使用,配置如下
import createPersistedState from "vuex-persistedstate"
import createLogger from 'vuex/dist/logger'
// 判斷環(huán)境 vuex提示生產(chǎn)環(huán)境中不使用
const debug = process.env.NODE_ENV !== 'production'
const createPersisted = createPersistedState({
storage: window.sessionStorage
})
export default new Vuex.Store({
// ...
plugins: debug ? [createLogger(), createPersisted] : [createPersisted]
})
plugins要是一個一維數(shù)組不然會解析錯誤
API
createPersistedState([options])使用給定的選項創(chuàng)建插件的新實例。可以提供以下選項來配置您的特定需求的插件:
key <String>:存儲持久狀態(tài)的鍵。(默認:vuex)
paths <Array>:部分持續(xù)狀態(tài)的任何路徑的數(shù)組。如果沒有路徑給出,完整的狀態(tài)是持久的。(默認:[])
reducer <Function>:一個函數(shù),將被調(diào)用來減少基于給定的路徑持久化的狀態(tài)。默認包含這些值。
subscriber <Function>:一個被調(diào)用來設(shè)置突變訂閱的函數(shù)。默認為store => handler => store.subscribe(handler)
storage <Object>:而不是(或與)getState和setState。默認為localStorage。
getState <Function>:將被調(diào)用以重新水化先前持久狀態(tài)的函數(shù)。默認使用storage。
setState <Function>:將被調(diào)用來保持給定狀態(tài)的函數(shù)。默認使用storage。
filter <Function>:將被調(diào)用來過濾將setState最終觸發(fā)存儲的任何突變的函數(shù)。默認為() => true
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
vue使用el-table篩選tree樹形結(jié)構(gòu)的數(shù)據(jù)問題
這篇文章主要介紹了vue使用el-table篩選tree樹形結(jié)構(gòu)的數(shù)據(jù)問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-07-07
vue中子組件向父組件傳遞數(shù)據(jù)的實例代碼(實現(xiàn)加減功能)
這篇文章主要介紹了vue中子組件向父組件傳遞數(shù)據(jù)的實例代碼(實現(xiàn)加減功能) ,需要的朋友可以參考下2018-04-04

