Vuex 強調(diào)使用單一狀態(tài)樹,即在一個項目里只有一個 store,這個 store 集中管理了項目中所有的數(shù)據(jù)以及對數(shù)據(jù)的操作行為。但是這樣帶來的問題是 store 可能會非常臃腫龐大不易維護,所以就需要對狀態(tài)樹進行模塊化的拆分。

 

首先貼出一個邏輯比較復(fù)雜的H5項目:源碼 & DEMO

該項目主要包括 banner、feeds、profile 三個部分。其中 feeds 模塊最復(fù)雜,需要對數(shù)據(jù)列表進行處理,如果單條數(shù)據(jù)中是圖片:1張按照屏幕寬展示;2張各占50%;3張以上采用九宮格形式展示;如果單條數(shù)據(jù)是視頻,則顯示播放按鈕,播放一條視頻時,其他視頻暫停。

由于該項目數(shù)據(jù)、交互較多,我們使用 Vuex 對數(shù)據(jù)進行托管,只在 Vue 組件中保留最基本的操作。

如果不使用 Vuex,許多數(shù)據(jù)流需要通過 props 的方便向下傳遞,十分不便,尤其是一些跨組件的操作更加困難。使用 Vuex 后就可以將數(shù)據(jù)與操作保留在 store 中,每個組件都能輕松調(diào)用。

延伸閱讀

學習是年輕人改變自己的最好方式-Java培訓,做最負責任的教育,學習改變命運,軟件學習,再就業(yè),大學生如何就業(yè),幫大學生找到好工作,lphotoshop培訓,電腦培訓,電腦維修培訓,移動軟件開發(fā)培訓,網(wǎng)站設(shè)計培訓,網(wǎng)站建設(shè)培訓學習是年輕人改變自己的最好方式