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

Vue如何實(shí)現(xiàn)利用vuex永久儲存數(shù)據(jù)

 更新時(shí)間:2023年04月17日 09:51:14   作者:玫瑰花開一片一片  
這篇文章主要介紹了Vue如何實(shí)現(xiàn)利用vuex永久儲存數(shù)據(jù)問題,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教

Vue用vuex永久儲存數(shù)據(jù)

首先需要在 vue項(xiàng)目上  安裝 vuex 與 vuex-persistedstate 

npm i vuex?
npm install --save vuex-persistedstate

1. 在 src 目錄下 創(chuàng)建 "store" 文件夾

2. 在store 文件夾下 創(chuàng)建 自定義 " index.js" 文件

3.在 index.js 中 import  引入 vue , vuex , persistedstate  并且使用use 方法是用 Vuex

4. 在store對象內(nèi)  plugins: [createPersistedState()],  使用 persistedstate 組件

5.把store文件夾 引入  main.js 中

最后  可以用 以下方法 訪問到數(shù)據(jù) , console.log(this.$store)  看下就明白了

this.$store.state

this.$store.commit('函數(shù)名','需要傳的參數(shù)')

import Vue from 'vue'
import Vuex from 'vuex'
import createPersistedState from 'vuex-persistedstate'
Vue.use(Vuex)
 
const store = new Vuex.Store({
  plugins: [createPersistedState()],
  state: {
    isLoading: false,
    num: ['1']
  },
  mutations: {
    loading (state, str) {
      let list = []
      list.push(str)
      state.num = [...state.num, ...list]
      console.log('ok')
    }
  }
})
export default store

基于vuex的數(shù)據(jù)持久化問題

存在問題

前端在使用vuex存儲數(shù)據(jù)的時(shí)候,一旦頁面刷新,所有之前存儲的數(shù)據(jù)就會丟失。這是因?yàn)閖s代碼運(yùn)行在內(nèi)存中,代碼在運(yùn)行時(shí),所有的變量和函數(shù)都是保存在內(nèi)存中的,因此在刷新時(shí),之前申請的內(nèi)存會被釋放,js腳本會被重新加載,變量重新賦值。

此問題映射在本項(xiàng)目上的體現(xiàn)

為了更直觀方便的處理數(shù)據(jù),一方面在數(shù)據(jù)庫中設(shè)置了服務(wù)類型表,另一方面在前端視圖層處理時(shí),將服務(wù)列表里的類型數(shù)據(jù)都統(tǒng)計(jì)一遍,存放在vuex的state中。

為了提高本項(xiàng)目的執(zhí)行效率,我在vuex中設(shè)置了一個flag布爾變量,初值為true,保證只有在第一次掛載組件時(shí)才向后臺發(fā)出請求,獲取所有服務(wù)信息,并且修改flag值為false。

但是這樣就會導(dǎo)致一個問題:下一次再重新登陸的時(shí)候,vuex數(shù)據(jù)刷新,但是不會再請求后臺數(shù)據(jù)了,因此得不到后臺的數(shù)據(jù)。

然后我又找了一個辦法,當(dāng)每次登陸的時(shí)候,把vuex中的flag值重新設(shè)置為true,這樣雖然解決了之前登陸之后沒有數(shù)據(jù)顯示的問題,但是同時(shí)也造成了另一個問題:數(shù)據(jù)累加,登陸一次所有之前的服務(wù)類型數(shù)據(jù)就會累加一次

解決方法:使用vuex的數(shù)據(jù)持久化

實(shí)現(xiàn)方式:

1.利用瀏覽器的本地存儲localStorage和sessionStorage

  • vuex的state在localStorage或sessionStorage取值
  • 在mutations里面,定義的方法對vuex的狀態(tài)操作的同時(shí),對存儲也做對應(yīng)的操作

2.利用vue-presistedstate插件

  • 原理和方法1一樣,也是結(jié)合了瀏覽器的本地存儲localStorage和sessionStorage,只不過是統(tǒng)一的配置,不需要每次都手寫存儲方法。
  • 安裝方式;npm install vuex-persistedstate --save
  • 引入:在store下的index.js中引入,然后使用插件plugins

本項(xiàng)目為了高效方便,采用了第二種下載插件的方式。

這樣就實(shí)現(xiàn)了vuex中數(shù)據(jù)持久化的效果,之前存儲的數(shù)據(jù)再刷新和退出之后就不會丟失了。

總結(jié)

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

相關(guān)文章

  • vue如何實(shí)現(xiàn)點(diǎn)擊選中取消切換

    vue如何實(shí)現(xiàn)點(diǎn)擊選中取消切換

    這篇文章主要介紹了vue實(shí)現(xiàn)點(diǎn)擊選中取消切換,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-05-05
  • vue如何根據(jù)權(quán)限生成動態(tài)路由、導(dǎo)航欄

    vue如何根據(jù)權(quán)限生成動態(tài)路由、導(dǎo)航欄

    這篇文章主要介紹了vue如何根據(jù)權(quán)限生成動態(tài)路由、導(dǎo)航欄,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-03-03
  • Vue組件開發(fā)之異步組件詳解

    Vue組件開發(fā)之異步組件詳解

    這篇文章主要為大家詳細(xì)介紹了Vue組件開發(fā)之異步組件,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助
    2022-02-02
  • vue-axios使用詳解

    vue-axios使用詳解

    本篇文章主要介紹了vue-axios使用詳解,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-05-05
  • vue微信分享 vue實(shí)現(xiàn)當(dāng)前頁面分享其他頁面

    vue微信分享 vue實(shí)現(xiàn)當(dāng)前頁面分享其他頁面

    這篇文章主要為大家詳細(xì)介紹了vue微信分享功能,vue實(shí)現(xiàn)當(dāng)前頁面分享其他頁面,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-12-12
  • 手把手教你Vue3如何封裝組件

    手把手教你Vue3如何封裝組件

    vue2和vue3的組件封裝還是有區(qū)別,下面這篇文章主要給大家介紹了關(guān)于Vue3如何封裝組件的相關(guān)資料,文中通過實(shí)例代碼介紹的非常詳細(xì),對大家學(xué)習(xí)或者使用vue3具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2023-02-02
  • vue路由跳轉(zhuǎn)傳參數(shù)的方法

    vue路由跳轉(zhuǎn)傳參數(shù)的方法

    這篇文章主要介紹了vue路由跳轉(zhuǎn)傳參數(shù)的方法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-05-05
  • Element el-row el-col 布局組件詳解

    Element el-row el-col 布局組件詳解

    這篇文章主要介紹了Element el-row el-col 布局組件使用,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-05-05
  • 使用Vue中 v-for循環(huán)列表控制按鈕隱藏顯示功能

    使用Vue中 v-for循環(huán)列表控制按鈕隱藏顯示功能

    這篇文章主要介紹了使用Vue中 v-for循環(huán)列表控制按鈕隱藏顯示功能,需要的朋友可以參考下
    2019-04-04
  • vue3限制table表格選項(xiàng)個數(shù)的解決方法

    vue3限制table表格選項(xiàng)個數(shù)的解決方法

    這篇文章主要為大家詳細(xì)介紹了vue3限制table表格選項(xiàng)個數(shù)的解決方法,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-04-04

最新評論