Vuex持久化插件(vuex-persistedstate)解決刷新數(shù)據(jù)消失的問題

頁面刷新后,想保存頁面未保存的數(shù)據(jù)。我們總是習(xí)慣于放在瀏覽器的sessionStorage和localStorage中。但是用了vue后,vuex便可以被應(yīng)用了。

創(chuàng)新互聯(lián)專注于企業(yè)營銷型網(wǎng)站、網(wǎng)站重做改版、鎮(zhèn)安網(wǎng)站定制設(shè)計、自適應(yīng)品牌網(wǎng)站建設(shè)、HTML5建站成都商城網(wǎng)站開發(fā)、集團公司官網(wǎng)建設(shè)、成都外貿(mào)網(wǎng)站制作、高端網(wǎng)站制作、響應(yīng)式網(wǎng)頁設(shè)計等建站業(yè)務(wù),價格優(yōu)惠性價比高,為鎮(zhèn)安等各大城市提供網(wǎng)站開發(fā)制作服務(wù)。

vuex優(yōu)勢:相比sessionStorage,存儲數(shù)據(jù)更安全,sessionStorage可以在控制臺被看到。

vuex劣勢:在F5刷新頁面后,vuex會重新更新state,所以,存儲的數(shù)據(jù)會丟失。

vuex可以進(jìn)行全局的狀態(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()]
})

默認(rèn)存儲到localStorage

想要存儲到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 {
   // 只儲存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)建插件的新實例??梢蕴峁┮韵逻x項來配置您的特定需求的插件:

key <String>:存儲持久狀態(tài)的鍵。(默認(rèn):vuex)

paths <Array>:部分持續(xù)狀態(tài)的任何路徑的數(shù)組。如果沒有路徑給出,完整的狀態(tài)是持久的。(默認(rèn):[])

reducer <Function>:一個函數(shù),將被調(diào)用來減少基于給定的路徑持久化的狀態(tài)。默認(rèn)包含這些值。

subscriber <Function>:一個被調(diào)用來設(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)用來保持給定狀態(tài)的函數(shù)。默認(rèn)使用storage。

filter <Function>:將被調(diào)用來過濾將setState最終觸發(fā)存儲的任何突變的函數(shù)。默認(rèn)為() => true

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持創(chuàng)新互聯(lián)。

本文名稱:Vuex持久化插件(vuex-persistedstate)解決刷新數(shù)據(jù)消失的問題
分享路徑:http://muchs.cn/article44/jejghe.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供軟件開發(fā)、App開發(fā)、全網(wǎng)營銷推廣、網(wǎng)站改版、網(wǎng)站內(nèi)鏈

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

外貿(mào)網(wǎng)站建設(shè)