您好,登錄后才能下訂單哦!
這篇文章主要講解了“關于vuex強刷數據丟失問題的解決方法”,文中的講解內容簡單清晰,易于學習與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學習“關于vuex強刷數據丟失問題的解決方法”吧!
核心原理:在本地存儲中存入所有的vuex數據,頁面刷新時到緩存中取數據,放到vuex中
下載:$ npm install vuex-persistedstate -S
在store中引入插件
import persistedState from 'vuex-persistedstate' const store = new Vuex.Store({ // ... plugins: [persistedState()] })
vuex-persistedstate
默認使用localStorage儲存,若想使用sessionStorage,可采用以下配置
import persistedState from "vuex-persistedstate" const store = new Vuex.Store({ // ... plugins: [persistedState ({ storage: window.sessionStorage })] })
若想使用cookie,可采用以下配置
下載:$ npm install js-cookie -S
import Cookies from 'js-cookie'; import persistedState from "vuex-persistedstate" const store = new Vuex.Store({ // ... plugins: [persistedState ({ storage: { getItem: key => Cookies.get(key), setItem: (key, value) => Cookies.set(key, value), removeItem: key => Cookies.remove(key) } })] })
加密storage
當我們在vuex中保存了用戶信息,雖然使用起來方便了很多,但是為了解決vuex刷新頁面數據丟失的問題,使用了vuex-persistedstate
插件,vuex-persistedstate
是沒有加密的,用戶的信息就暴露在緩存中,
非常的不安全,所以需要配合secure-ls
來加密storage
下載: $ npm install secure-ls -S
import Vue from "vue"; import Vuex from "vuex"; import SecureLS from 'secure-ls'; import persistedState from "vuex-persistedstate"; const ls = new SecureLS({ encodingType: "aes", // 加密方式 isCompression: false, // 是否啟用數據壓縮 encryptionSecret: "old-beauty" // }); Vue.use(Vuex); export default new Vuex.Store({ ... plugins: [persistedState({ // key: "123123", // 存入storage是的key storage: { getItem: key => ls.get(key), setItem: (key, value) => ls.set(key, value), removeItem: key => ls.remove(key) } })], });
【注】vuex-persist(不兼容ie) vuex-persistedstate
感謝各位的閱讀,以上就是“關于vuex強刷數據丟失問題的解決方法”的內容了,經過本文的學習后,相信大家對關于vuex強刷數據丟失問題的解決方法這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是億速云,小編將為大家推送更多相關知識點的文章,歡迎關注!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。