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

在nuxt使用vueX代替storage的實現(xiàn)方案

 更新時間:2023年10月11日 10:29:50   作者:fireInMapleForest  
這篇文章主要介紹了在nuxt使用vueX代替storage的實現(xiàn)方案,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教

使用vuex代替本地緩存storage

今天搬項目時,發(fā)現(xiàn)頁面中有使用sessionStorage做緩存便于各頁面使用,但是搬到nuxt結構下卻報錯了,查詢發(fā)現(xiàn)是由于在vue-nuxt中是沒辦法使用window和document,所以本地緩存也會出問題。

因此只能找替代方案,于是想到了vueX(原本項目是沒有用的);

參照Nuxt使用Vuex將基礎store寫完了,結果卻發(fā)現(xiàn)頁面報錯了:

Classic mode for store/ is deprecated and will be removed in Nuxt 3.

沒辦法繼續(xù)祭出百度大法,發(fā)現(xiàn)是 vuex經(jīng)典模式寫法將在Nuxt 3中刪除。

在nuxt不需要按照經(jīng)典模式寫了

//經(jīng)典模式
import Vue from 'vue'
import Vuex from 'vuex'
Vue.use(Vuex)
const store = () => new Vuex.Store({
  state: {
    counter: 0
  },
  mutations: {
    addCounter(state) {
      state.counter++
    }
  }
})
export default store

區(qū)別在于:

1、不需要 modules 目錄,所有 modules 直接寫出 xxx.js 就是模塊了。

2、index中不需要 vue.use(vuex) 等模板代碼了,全部由 nuxt 完成。

3、action 需要自己寫,默認 nuxt會自動配置生成。直接調(diào)用即可。

//新版示例
export  const state = () => ({
	userInfo: null,
	token: null,
})
export const getters = {
  getToken(state){
    return state.token
  },
}
export const mutations = {
  set_userInfo(state, userInfo) {
      state.userInfo = userInfo;
  },
  set_token(state, token) {
      state.token = token;
  },
}
export const actions = {
	//do ajax
}

獲取更改的方式還是沒變

this.$store.state.token;
this.$store.commit('set_token',token);

到這里基本上完成,當我高高興興準備繼續(xù)時,刷新了下頁面,數(shù)據(jù)沒了!?。?!

nuxt中頁面刷新后原來的vueX的數(shù)據(jù)獲取不到了

這樣不行,只能繼續(xù)想辦法了,然后通過百度大法還真讓我找到了

nuxt中刷新頁面后防止store值丟失

按照這個我又開始了我的搬遷大業(yè),結果發(fā)現(xiàn)這個值只能在頁面徹底加載后才生效

這樣導致我在mouted生命周期里壓根沒法實現(xiàn),哦豁,這就很尷尬了。

后面我想了下我要是不加這個判斷會怎么樣,想到就干,還真成功了

//離開頁面 刷新前 將store中的數(shù)據(jù)存到session
    window.addEventListener('beforeunload', ()=> {
        sessionStorage.setItem("storeCache",JSON.stringify(ctx.store.state))
    });
    //頁面加載完成  將session中的store數(shù)據(jù)
    // window.addEventListener('load', ()=> {
        let storeCache = sessionStorage.getItem("storeCache")
        if(storeCache){
            // 將session中的store數(shù)據(jù)替換到store中
            ctx.store.replaceState(JSON.parse(storeCache));
        }
    // });

屏蔽掉后我成功在mouted中拿到了值。

搬遷大業(yè)不易啊,繼續(xù)努力?。。?/p>

打開新窗口后,數(shù)值回歸初始值的問題

這是今天在搬遷代碼的時候發(fā)現(xiàn)另一個問題,正常情況下頁面路由跳轉都在同一窗口。

但是也有一些另外的情況,比如通過a標簽的_blank屬性、window.open(url, ‘_blank’);等方式,重新打開一個窗口;這時我發(fā)現(xiàn),我本來的登錄狀態(tài)信息沒有了,緩存里也變成了初始值。

經(jīng)過調(diào)試發(fā)現(xiàn)跳轉重新打開頁面時,部分代碼不生效了

因為這部分保存代碼有個前提,離開當前頁面或者刷新才會生效,但是我是打開了新窗口,原有的窗口是沒有任何變化的,也就是說。

在我第一次登陸的時候,跳轉打開新窗口,此時得到的數(shù)據(jù)并不會是最新的登陸之后的信息,而會是初始值。

于是想了想能否使用路由守衛(wèi)進行判斷,只要進行了跳轉就保存一次,于是我就干了,我想著把js的代碼進行更換為路由形式,嘗試了幾次終于是成功了

export default ( ctx ) => {
	let toU;
	ctx.app.router.afterEach((to, from) => {
		toU = to;
	})
	if(toU){
		sessionStorage.setItem("storeCache",JSON.stringify(ctx.store.state))
	}
	let storeCache = sessionStorage.getItem("storeCache")
	if(storeCache){
		// 將session中的store數(shù)據(jù)替換到store中
		ctx.store.replaceState(JSON.parse(storeCache));
	}
}

總結

以上為個人經(jīng)驗,該方式只是個人項目中能夠實現(xiàn),不保證廣泛性,僅作參考!希望大家多多支持腳本之家。

相關文章

  • vue3清空let?arr?=?reactive([])的實現(xiàn)示例

    vue3清空let?arr?=?reactive([])的實現(xiàn)示例

    本文主要介紹了vue3清空let?arr?=?reactive([])的實現(xiàn)示例,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2025-03-03
  • Vue在原窗口與新窗口打開外部鏈接的實現(xiàn)代碼

    Vue在原窗口與新窗口打開外部鏈接的實現(xiàn)代碼

    這篇文章主要介紹了Vue如何在原窗口與新窗口打開外部鏈接,文中給大家提到了vue跳轉外部鏈接的實現(xiàn)代碼,本文給大家介紹的非常詳細,需要的朋友可以參考下
    2023-02-02
  • Vue常見組件間通信方案及典型應用場景詳解

    Vue常見組件間通信方案及典型應用場景詳解

    這篇文章主要為大家介紹了Vue常見組件間通信方案及典型應用場景詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-09-09
  • vue自定義filters過濾器

    vue自定義filters過濾器

    這篇文章主要介紹了vue自定義filters過濾器的相關知識,非常不錯,具有參考借鑒價值,需要的朋友參考下吧
    2018-04-04
  • vue遞歸獲取父元素的元素實例

    vue遞歸獲取父元素的元素實例

    這篇文章主要介紹了vue遞歸獲取父元素的元素實例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-08-08
  • Vue項目中實現(xiàn)描點跳轉scrollIntoView的案例

    Vue項目中實現(xiàn)描點跳轉scrollIntoView的案例

    這篇文章主要介紹了Vue項目中實現(xiàn)描點跳轉scrollIntoView的案例,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-09-09
  • vue中destroyed方法及使用示例講解

    vue中destroyed方法及使用示例講解

    這篇文章主要為大家介紹了vue中destroyed方法及使用示例講解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-06-06
  • 使用 webpack 插件自動生成 vue 路由文件的方法

    使用 webpack 插件自動生成 vue 路由文件的方法

    這篇文章主要介紹了使用 webpack 插件自動生成 vue 路由文件的方法,本文通過實例代碼給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下
    2019-08-08
  • el-table實現(xiàn)給每行添加loading效果案例

    el-table實現(xiàn)給每行添加loading效果案例

    這篇文章主要介紹了el-table實現(xiàn)給每行添加loading效果案例,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-08-08
  • vue中typescript裝飾器的使用方法超實用教程

    vue中typescript裝飾器的使用方法超實用教程

    這篇文章主要介紹了vue中使用typescript裝飾器的使用方法超實用教程,非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下
    2019-06-06

最新評論