vuex 閒置狀態重置方案

2021-09-14 03:14:20 字數 2421 閱讀 9749

大型單頁應用(後面都是指spa),我們往往會通過使用狀態管理器 vuex 去解決元件間狀態共享與狀態傳遞等問題。這種應用少則幾十個單頁,多則上百個單頁。隨著路由的頻繁切換,每個路由對應的 vuex 中的狀態將越來越多。為了做到頁面的極致優化,我們需要將那些閒置的狀態重置,以減小占用的記憶體空間。

vuex 強調採用集中式儲存管理應用的所有元件的狀態,但是我們真把所有的狀態都放到 store 中去處理,你會發現開發起來非常痛苦。這裡如果想很好的把控哪些資料需要放到 store 中去管理,首先要理解 vuex 是用來解決什麼問題的。vuex 官網指出是為了解決多個元件共享狀態的,那麼我們就可以把多個元件的共享狀態放到 store 中去管理,這裡的多元件共享對於單頁應用很多情況是跨路由的元件。如果 store只儲存多元件共享的狀態,那麼我們就沒必要去清理 vuex 中的狀態了,因為這些狀態隨時會被用到。

而隨著業務場景越來越複雜,很多與後台互動的邏輯也都放到了元件中,這樣**就變得很凌亂,vuex 也沒有被充分利用。這時我們可以把與後台 api 互動的邏輯放到 vuex 中的action 去處理,後台返回的狀態自然也就放到了 store 管理。這樣處理後,元件就只負責對資料進行渲染,邏輯非常清晰。而此時,元件對應的 store 中的狀態隨著路由的切換將會越來越多,而這些狀態就需要我們手動的去清理了。

很多方案都有取捨,如果將與後台 api 互動的資料放到元件中,就沒必要去清理了,但是**邏輯將變得比較亂。另外諸如 vuex 的外掛程式

vue-devtools 將無法監控到每次請求資料的變化...

我們想要的效果是在路由切換的時候,把上乙個路由對應的 vuex 中的狀態重置掉,但是路由和vuex 並沒有一一對應的關係,如果要做到這種效果,那麼我們需要維護乙個路由與vuex 模組的對應關係,這樣會很繁瑣。不如當路由改變時去重置 vuex 中的所有狀態。

下面將結合我的github例項去說明,這個例項建立了乙個單頁應用,我們通過切換路由的時候將閒置的狀態清除。

例項中採用拆分 store 為多個 module 的方式,將路由對應的元件狀態放到對應的 module 中,多元件共享的狀態放到頂級的 store 中管理。大致如下:

// store/index.js

import page1 from "./modules/page1.js";

import page2 from "./modules/page2.js";

import page3 from "./modules/page3.js";

import page4 from "./modules/page4.js";

import page5 from "./modules/page5.js";

export default new vuex.store(,

plugins: __dev__ ? [createlogger()] : ,

strict: __dev__ ? true : false

});

路由 page1 對應的 module 的 state 形如:

// store/modules/page1.js

const state =

這些資料是通過呼叫後端 api 返回並複製的資料,如果我們在路由改變的時候重置這些資料,那麼需要將初始化資料提取出來,並且暴露乙個需要重置的標識方法initstate(),代表路由改變的時候需要重置,當然這個方法名稱是個約定,你也可以定義為其他名稱。改造後為:

// store/modules/page1.js

// 放置你要重置的資料

const initstate =

// state

const state =

}

定義全域性 mutation 事件型別

// store/types.js

export const reset_states = 'resetstates'

定義全域性 mutation

// store/mutation.js

import * as types from './types'

// 檢測所有的 state 並把 `initstate()` 中的屬性重置

function resetstate(state, modulestate)

}}export default

},}

定義全域性 action

// store/action.js

import * as types from './types'

export default

}

至此一切準備就緒,只需要在路由改變時觸發重置的方法即可,在入口 vue 檔案中處理

--完--

重置vuex所有state的狀態

效果 思路 主要是在store首次生成state後深拷貝出乙份備份,然後在reset方法中將各個屬性還原回去,注意最重要的是不要破壞原來資料的結構 我之前還看到有人用delete,資料屬性都沒了肯定是會報錯的 步驟1準備乙個深拷貝方法 定義乙個深拷貝函式 接收目標target引數 deepclone...

vue 重置vuex資料

有時候在我們把資料儲存下來的時候,在某個時候需要移除這些資料卻不知道怎麼移除了 下面我有一些自己的方法 一 dispatch重新賦值 store.js const actions targetuser vue頁面 賦空值 methods 方法二 在actions定義乙個方法 const action...

狀態管理庫vuex 狀態管理庫vuex

vuex是乙個專為vue.js應用程式開發的管理庫。狀態就是指元件之間共享的資料 vue專案中配置狀態管理庫vuex的流程 2建立狀態管理庫物件store 3對外丟擲store物件 4在mian.js中將store物件與當前專案相關聯 vuex是乙個專為vue.js應用程式開發的管理庫。狀態就是指元...