亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

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

發布時間:2020-09-06 09:36:55 來源:腳本之家 閱讀:238 作者:JasonEnding 欄目:web開發

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

vuex優勢:相比sessionStorage,存儲數據更安全,sessionStorage可以在控制臺被看到。

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

vuex可以進行全局的狀態管理,但刷新后刷新后數據會消失,這是我們不愿意看到的。怎么解決呢,我們可以結合本地存儲做到數據持久化,也可以通過插件-vuex-persistedstate。

1.手動利用HTML5的本地存儲

方法

  • vuex的state在localStorage或sessionStorage或其它存儲方式中取值
  • 在mutations,定義的方法里對vuex的狀態操作的同時對存儲也做對應的操作。這樣state就會和存儲一起存在并且與vuex同步

問題

最直觀的就是,手動寫比較麻煩。

2.利用vuex-persistedstate插件

插件的原理其實也是結合了存儲方式,只是統一的配置就不需要手動每次都寫存儲方法

使用方法

安裝

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'
// 判斷環境 vuex提示生產環境中不使用
const debug = process.env.NODE_ENV !== 'production'
const createPersisted = createPersistedState({
 storage: window.sessionStorage
})
export default new Vuex.Store({
 // ...
 plugins: debug ? [createLogger(), createPersisted] : [createPersisted]
})

plugins要是一個一維數組不然會解析錯誤

API

createPersistedState([options])使用給定的選項創建插件的新實例。可以提供以下選項來配置您的特定需求的插件:

key <String>:存儲持久狀態的鍵。(默認:vuex)

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

reducer <Function>:一個函數,將被調用來減少基于給定的路徑持久化的狀態。默認包含這些值。

subscriber <Function>:一個被調用來設置突變訂閱的函數。默認為store => handler => store.subscribe(handler)

storage <Object>:而不是(或與)getState和setState。默認為localStorage。

getState <Function>:將被調用以重新水化先前持久狀態的函數。默認使用storage。

setState <Function>:將被調用來保持給定狀態的函數。默認使用storage。

filter <Function>:將被調用來過濾將setState最終觸發存儲的任何突變的函數。默認為() => true

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持億速云。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

峨边| 金阳县| 原平市| 双桥区| 晋宁县| 辰溪县| 上栗县| 萨嘎县| 安溪县| 南和县| 莱西市| 冀州市| 安远县| 博罗县| 洛南县| 元氏县| 大石桥市| 称多县| 栖霞市| 枝江市| 石柱| 青铜峡市| 石家庄市| 治多县| 汝城县| 上饶市| 孝昌县| 乌拉特中旗| 通化县| 伊通| 电白县| 含山县| 临洮县| 祥云县| 海安县| 西藏| 平原县| 镇坪县| 辉县市| 瑞丽市| 定兴县|