欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

vuex中數(shù)據(jù)持久化插件vuex-persistedstate使用詳解

 更新時間:2022年03月30日 10:08:18   作者:JackieDYH  
這篇文章主要介紹了vuex中數(shù)據(jù)持久化插件vuex-persistedstate使用詳解,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教

數(shù)據(jù)持久化vuex-persistedstate使用

vuex是在中大型項目中必不可少的狀態(tài)管理組件,刷新會重新更新狀態(tài),但是有時候我們并不希望如此。例如全局相關的,如登錄狀態(tài)、token、以及一些不常更新的狀態(tài)等,我們更希望能夠固化到本地,減少無用的接口訪問,以及更佳的用戶體驗。

安裝起步

npm i vuex-persistedstate --save

目前的環(huán)境版本:

"vue": "^2.5.2",
"vue-router": "^3.0.1",
"vuex": "^3.4.0",
"vuex-persistedstate": "^3.0.1",

vuex已經(jīng)升級到了3,看了release note沒有發(fā)現(xiàn)太過分的升級,預計不會出現(xiàn)不兼容的情況,有感興趣的小伙伴可以升級體驗一下。

配置使用

在vuex初始化時候,作為組件引入。

import persistedState from 'vuex-persistedstate'
export default new Vuex.Store({
? ? // ...
? ? plugins: [persistedState()]
})

自定義存儲方式

vuex-persistedstate默認使用localStorage來固化數(shù)據(jù),一些特殊情況要如何應對呢?(如:safari的無痕瀏覽模式)

需要使用sessionStorage的情況

plugins: [
? ? persistedState({ storage: window.sessionStorage })
]

使用cookie的情況

import persistedState from 'vuex-persistedstate'
import * as Cookies from 'js-cookie'
export default new Vuex.Store({
? // ...
? plugins: [
? ? persistedState({
? ? ? storage: {
? ? ? ? getItem: key => Cookies.get(key),
? ? ? ? setItem: (key, value) => Cookies.set(key, value, { expires: 7 }),
? ? ? ? removeItem: key => Cookies.remove(key)
? ? ? }
? ? })
? ]
})

想使用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ù)組不然會解析錯誤

使用vuex-persistedstate插件遇到的問題

這是一個做持久化的插件:vuex-persistedstate

 我在做項目時,遇到一個問題,就是做下面這個功能,渲染數(shù)據(jù)的時候,因為這個數(shù)據(jù)好多個地方使用,所以呢,把它存到了vuex里面。vuex 是將數(shù)據(jù)存到了瀏覽器的內(nèi)存中,刷新就沒了

這行代碼是寫在vuex里面的,就是說,我直接從本地去拿數(shù)據(jù)

list: JSON.parse(window.localStorage.getItem('abc')).category.list || []

直接看下代碼: 我一開始是這樣想的,既然我vuex中有數(shù)據(jù)了,不用計算屬性行不行,直接渲染,確實可以渲染,但是品牌這一項咋渲染呢,push行不通啊,那就只能把結構寫死,但是頁面效果就不對了,所以這個地方用計算屬性,第一,動態(tài)的取到前兩項,第二,可以動態(tài)的添加新的 li 結構。

計算屬性使用的場景:有數(shù)據(jù)啦,但不是我想要的格式,要加工加工

 setup () {
    const brand = reactive({
      id: 'brand',
      name: '品牌',
      children: [{ id: 'brand-children', name: '品牌推薦' }]
    })
    const store = useStore()
    const cateList = computed(() => {
      const list = store.state.category.list.map(item => {
        return {
          id: item.id,
          name: item.name,
          children: item.children && item.children.slice(0, 2)
        }
      })
      list.push(brand)
      return list
    })
    return { cateList }
  }

以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關文章

  • vue中的stylus及stylus-loader版本問題

    vue中的stylus及stylus-loader版本問題

    這篇文章主要介紹了vue中的stylus及stylus-loader版本問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-08-08
  • VUE3安裝element?ui失敗的原因以及解決辦法

    VUE3安裝element?ui失敗的原因以及解決辦法

    這篇文章主要給大家介紹了關于VUE3安裝element?ui失敗的原因以及解決的相關資料,很多朋友升級使用Vue3了,但在安裝element?ui失敗出錯了,這里給大家總結下,需要的朋友可以參考下
    2023-09-09
  • vue-video-player視頻播放器使用配置詳解

    vue-video-player視頻播放器使用配置詳解

    這篇文章主要為大家詳細介紹了vue-video-player視頻播放器的使用和配置,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-10-10
  • Vue 2.0 基礎詳細

    Vue 2.0 基礎詳細

    這篇文章主要介紹了Vue 2.0 基礎,具體內(nèi)容有、基本語法、生命周期、路由管理Vue-Router、狀態(tài)管理Vuex、Http請求庫Axios,想詳細了解的小伙伴請和現(xiàn)編一起學習下面文章內(nèi)容吧
    2021-10-10
  • 詳解最新vue-cli 2.9.1的webpack存在問題

    詳解最新vue-cli 2.9.1的webpack存在問題

    這篇文章主要介紹了最新vue-cli 2.9.1的webpack存在問題,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-12-12
  • vue實現(xiàn)輪播圖幀率播放

    vue實現(xiàn)輪播圖幀率播放

    這篇文章主要為大家詳細介紹了vue實現(xiàn)輪播圖幀率播放,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-01-01
  • vant組件中 dialog的確認按鈕的回調(diào)事件操作

    vant組件中 dialog的確認按鈕的回調(diào)事件操作

    這篇文章主要介紹了vant組件中 dialog的確認按鈕的回調(diào)事件操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-11-11
  • 使用vue-router完成簡單導航功能【推薦】

    使用vue-router完成簡單導航功能【推薦】

    vue-router是Vue.js官方提供的一套專用的路由工具庫。這篇文章主要介紹了使用vue-router完成簡單導航功能,需要的朋友可以參考下
    2018-06-06
  • Vue路由跳轉傳參或者打開新頁面跳轉問題

    Vue路由跳轉傳參或者打開新頁面跳轉問題

    這篇文章主要介紹了Vue路由跳轉傳參或者打開新頁面跳轉問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-03-03
  • React和Vue實現(xiàn)路由懶加載的示例代碼

    React和Vue實現(xiàn)路由懶加載的示例代碼

    路由懶加載是一項關鍵技術,它可以幫助我們提高Web應用的加載速度,本文主要介紹了React和Vue實現(xiàn)路由懶加載的示例代碼,具有一定的參考價值,感興趣的可以了解一下
    2024-01-01

最新評論