您好,登錄后才能下訂單哦!
頁(yè)面刷新后,想保存頁(yè)面未保存的數(shù)據(jù)。我們總是習(xí)慣于放在瀏覽器的sessionStorage和localStorage中。但是用了vue后,vuex便可以被應(yīng)用了。
vuex優(yōu)勢(shì):相比sessionStorage,存儲(chǔ)數(shù)據(jù)更安全,sessionStorage可以在控制臺(tái)被看到。
vuex劣勢(shì):在F5刷新頁(yè)面后,vuex會(huì)重新更新state,所以,存儲(chǔ)的數(shù)據(jù)會(huì)丟失。
vuex可以進(jìn)行全局的狀態(tài)管理,但刷新后刷新后數(shù)據(jù)會(huì)消失,這是我們不愿意看到的。怎么解決呢,我們可以結(jié)合本地存儲(chǔ)做到數(shù)據(jù)持久化,也可以通過(guò)插件-vuex-persistedstate。
1.手動(dòng)利用HTML5的本地存儲(chǔ)
方法
問(wèn)題
最直觀的就是,手動(dòng)寫(xiě)比較麻煩。
2.利用vuex-persistedstate插件
插件的原理其實(shí)也是結(jié)合了存儲(chǔ)方式,只是統(tǒng)一的配置就不需要手動(dòng)每次都寫(xiě)存儲(chǔ)方法
使用方法
安裝
npm install vuex-persistedstate --save
引入及配置
在store下的index.js中
import createPersistedState from "vuex-persistedstate" const store = new Vuex.Store({ // ... plugins: [createPersistedState()] })
默認(rèn)存儲(chǔ)到localStorage
想要存儲(chǔ)到sessionStorage,配置如下
import createPersistedState from "vuex-persistedstate" const store = new Vuex.Store({ // ... plugins: [createPersistedState({ storage: window.sessionStorage })] })
想使用cookie同理
默認(rèn)持久化所有state
指定需要持久化的state,配置如下
import createPersistedState from "vuex-persistedstate" const store = new Vuex.Store({ // ... plugins: [createPersistedState({ storage: window.sessionStorage, reducer(val) { return { // 只儲(chǔ)存state中的assessmentData assessmentData: val.assessmentData } } })]
vuex引用多個(gè)插件的寫(xiě)法
譬如: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要是一個(gè)一維數(shù)組不然會(huì)解析錯(cuò)誤
API
createPersistedState([options])使用給定的選項(xiàng)創(chuàng)建插件的新實(shí)例??梢蕴峁┮韵逻x項(xiàng)來(lái)配置您的特定需求的插件:
key <String>:存儲(chǔ)持久狀態(tài)的鍵。(默認(rèn):vuex)
paths <Array>:部分持續(xù)狀態(tài)的任何路徑的數(shù)組。如果沒(méi)有路徑給出,完整的狀態(tài)是持久的。(默認(rèn):[])
reducer <Function>:一個(gè)函數(shù),將被調(diào)用來(lái)減少基于給定的路徑持久化的狀態(tài)。默認(rèn)包含這些值。
subscriber <Function>:一個(gè)被調(diào)用來(lái)設(shè)置突變訂閱的函數(shù)。默認(rèn)為store => handler => store.subscribe(handler)
storage <Object>:而不是(或與)getState和setState。默認(rèn)為localStorage。
getState <Function>:將被調(diào)用以重新水化先前持久狀態(tài)的函數(shù)。默認(rèn)使用storage。
setState <Function>:將被調(diào)用來(lái)保持給定狀態(tài)的函數(shù)。默認(rèn)使用storage。
filter <Function>:將被調(diào)用來(lái)過(guò)濾將setState最終觸發(fā)存儲(chǔ)的任何突變的函數(shù)。默認(rèn)為() => true
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持億速云。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。