摘要:它采用集中式存儲管理應用的所有組件的狀態,并以相應的規則保證狀態以一種可預測的方式發生變化。頁面上,負責接收用戶操作等交互行為,執行方法觸發對應進行回應。狀態改變提交操作方法。集中存儲中對象的零散數據,全局唯一,以進行統一的狀態管理。
一、前言
當我們的應用遇到多個組件共享狀態時,會需要多個組件依賴于同一狀態抑或是來自不同視圖的行為需要變更同一狀態。以前的解決辦法:
a.將數據以及操作數據的行為都定義在父組件;
b.將數據以及操作數據的行為傳遞給需要的各個子組件(有可能需要多級傳遞)
傳參的方法對于多層嵌套的組件將會非常繁瑣,并且對于兄弟組件間的狀態傳遞無能為力。在搭建下面頁面時,你可能會對 vue 組件之間的通信感到崩潰 ,特別是非父子組件之間通信。此時就應該使用vuex,輕松可以搞定組件間通信問題。
二、什么是VuexVuex 是一個專為 Vue.js 應用程序開發的狀態管理模式。它采用集中式存儲管理應用的所有組件的狀態,并以相應的規則保證狀態以一種可預測的方式發生變化。這里的關鍵在于集中式存儲管理。簡單來說,對 vue 應用中多個組件的共享狀態進行集中式的管理(讀/寫)。
三、Vuex的原理是什么 1.簡要介紹Vuex原理Vuex實現了一個單向數據流,在全局擁有一個State存放數據,當組件要更改State中的數據時,必須通過Mutation進行,Mutation同時提供了訂閱者模式供外部插件調用獲取State數據的更新。而當所有異步操作(常見于調用后端接口異步獲取更新數據)或批量的同步操作需要走Action,但Action也是無法直接修改State的,還是需要通過Mutation來修改State的數據。最后,根據State的變化,渲染到視圖上。
2.簡要介紹各模塊在流程中的主要功能:Vue Components:Vue組件。HTML頁面上,負責接收用戶操作等交互行為,執行dispatch方法觸發對應action進行回應。
dispatch:操作行為觸發方法,是唯一能執行action的方法。
actions:操作行為處理模塊,由組件中的$store.dispatch("action 名稱", data1)來觸發。然后由commit()來觸發mutation的調用 , 間接更新 state。負責處理Vue Components接收到的所有交互行為。包含同步/異步操作,支持多個同名方法,按照注冊的順序依次觸發。向后臺API請求的操作就在這個模塊中進行,包括觸發其他action以及提交mutation的操作。該模塊提供了Promise的封裝,以支持action的鏈式觸發。
commit:狀態改變提交操作方法。對mutation進行提交,是唯一能執行mutation的方法。
mutations:狀態改變操作方法,由actions中的commit("mutation 名稱")來觸發。是Vuex修改state的唯一推薦方法。該方法只能進行同步操作,且方法名只能全局唯一。操作之中會有一些hook暴露出來,以進行state的監控等。
state:頁面狀態管理容器對象。集中存儲Vue components中data對象的零散數據,全局唯一,以進行統一的狀態管理。頁面顯示所需的數據從該對象中進行讀取,利用Vue的細粒度數據響應機制來進行高效的狀態更新。
getters:state對象讀取方法。圖中沒有多帶帶列出該模塊,應該被包含在了render中,Vue Components通過該方法讀取全局state對象。
四、什么時候使用Vuex雖然 Vuex 可以幫助我們管理共享狀態,但也附帶了更多的概念和框架。這需要對短期和長期效益進行權衡。
如果您的應用夠簡單,您最好不要使用 Vuex,因為使用 Vuex 可能是繁瑣冗余的。一個簡單的?global event bus?就足夠您所需了。但是,如果您需要構建一個中大型單頁應用,您很可能會考慮如何更好地在組件外部管理狀態,Vuex 將會成為自然而然的選擇。
首先要安裝vue-cli腳手架,對于大陸用戶,建議將npm的注冊表源設置為國內的鏡像(淘寶鏡像),可以大幅提升安裝速度。
npm config set registry https://[registry.npm.taobao.org](http://registry.npm.taobao.org/) npm config get registry//配置后可通過下面方式來驗證是否成功 npm install -g cnpm --registry=[https://registry](https://registry/).npm.taobao.org //cnpm安裝腳手架 cnpm install -g vue-cli vue init webpack my-vue cd my-vue cnpm install cnpm run dev
腳手架安裝好后,再安裝vuex
cnpm install vuex --save六、如何使用Vuex 1.如何通過Vue來實現如下效果?
這個小demo很容易用vue實現,核心代碼如下:
2.如何通過Vuex來改造上面代碼? ①創建一個store.js文件...... export default { name: "HelloWorld", data() { return { count: 0 }; }, computed: { evenOrOdd() { return this.count % 2 === 0 ? "偶數" : "奇數"; } }, methods: { increment() { this.count = this.count + 1; }, decrement() { this.count = this.count - 1; }, // 只有是奇數才加1 incrementIfOdd() { if (this.count % 2 === 1) { this.count = this.count + 1; } }, // 過兩秒才加1 incrementAsync() { setInterval(() => { this.count = this.count + 1; }, 2000); } } }click {{count}} times,count is {{evenOrOdd}}
import Vue from "vue" import Vuex from "vuex" Vue.use(Vuex) const store = new Vuex.Store({ state: { count: 0 }, mutations: {// 包含了多個直接更新state函數的對象 INCREMENT(state) { state.count = state.count + 1; }, DECREMENT(state) { state.count = state.count - 1; } }, getters: { // 當讀取屬性值時自動調用并返回屬性值 evenOrOdd(state) { return state.count % 2 === 0 ? "偶數" : "奇數"; } }, actions: { // 包含了多個對應事件回調函數的對象 incrementIfOdd({ commit, state }) { // 帶條件的action if (state.count % 2 === 1) { commit("INCREMENT") } }, incrementAsync({ commit }) { //異步的action setInterval(() => { commit("INCREMENT") }, 2000); } } }) export default store //用export default 封裝代碼,讓外部可以引用②在main.js文件中引入store.js文件
import store from "./store" new Vue({ el: "#app", router, store,//注冊上vuex的store: 所有組件對象都多一個屬性$store components: { App }, template: "③新建一個模板HelloWorld.vue" })
click {{count}} times,count is {{evenOrOdd}}
由于 store 中的狀態是響應式的,當 Vue 組件從 store 中讀取狀態的時候,若 store 中的狀態發生變化,那么相應的組件也會相應地得到高效更新。在組件中調用 store 中的狀態簡單到僅需要在計算屬性中返回即可。改變store 中的狀態的唯一途徑就是顯式地提交 (commit) mutations。
3.如何通mapState等輔助函數優化上面代碼?import { mapActions, mapGetters, mapState, mapMutations } from "vuex"; ... computed: { ...mapState(["count"]), ...mapGetters(["evenOrOdd"]) } methods: { ...mapActions(["incrementIfOdd", "incrementAsync"]), ...mapMutations(["increment", "decrement"]) }
有點必須要注意:HelloWorld.vue文件中increment函數名稱要跟store.js文件mutations中一致,才可以寫成 ...mapMutations(["increment", "decrement"]),同樣的道理,incrementIfOdd和incrementAsync也要和store.js文件actions保持一致。
七、使用Vuex的注意點 1.如何在Mutations里傳遞參數先store.js文件里給add方法加上一個參數n
mutations: { INCREMENT(state,n) { state.count+=n; }, DECREMENT(state){ state.count--; } }
然后在HelloWorld.vue里修改按鈕的commit( )方法傳遞的參數
increment() { return this.$store.commit("INCREMENT",2); }, decrement() { return this.$store.commit("DECREMENT"); }2.如何理解getters
getters從表面是獲得的意思,可以把他看作在獲取數據之前進行的一種再編輯,相當于對數據的一個過濾和加工。getters就像計算屬性一樣,getter 的返回值會根據它的依賴被緩存起來,且只有當它的依賴值發生了改變才會被重新計算。
例如:要對store.js文件中的count進行操作,在它輸出前,給它加上100。
首先要在store.js里Vuex.Store()里引入getters
getters:{ count:state=>state.count+=100 }
然后在HelloWorld.vue中對computed進行配置,在vue 的構造器里邊只能有一個computed屬性,如果你寫多個,只有最后一個computed屬性可用,所以要用展開運算符”…”對上節寫的computed屬性進行一個改造。
computed: { ...mapGetters(["count"]) }3.actions和mutations區別
actions和上面的Mutations功能基本一樣,不同點是,actions是異步的改變state狀態,而Mutations是同步改變狀態。
同步的意義在于這樣每一個 mutation 執行完成后都可以對應到一個新的狀態(和 reducer 一樣),這樣 devtools 就可以打個 snapshot 存下來,然后就可以隨便 time-travel 了。如果你開著 devtool 調用一個異步的 action,你可以清楚地看到它所調用的 mutation 是何時被記錄下來的,并且可以立刻查看它們對應的狀態----尤雨溪
ps:如果想訪問源代碼,請猛戳git地址
如果覺得文章對你有些許幫助,歡迎在我的GitHub博客點贊和關注,感激不盡!
參考文章vuex官方文檔
Vuex 2.0 源碼分析
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/114059.html
摘要:它采用集中式存儲管理應用的所有組件的狀態,并以相應的規則保證狀態以一種可預測的方式發生變化。頁面上,負責接收用戶操作等交互行為,執行方法觸發對應進行回應。狀態改變提交操作方法。集中存儲中對象的零散數據,全局唯一,以進行統一的狀態管理。 一、前言 當我們的應用遇到多個組件共享狀態時,會需要多個組件依賴于同一狀態抑或是來自不同視圖的行為需要變更同一狀態。以前的解決辦法: a.將數據以及操作...
摘要:它采用集中式存儲管理應用的所有組件的狀態,并以相應的規則保證狀態以一種可預測的方式發生變化。頁面上,負責接收用戶操作等交互行為,執行方法觸發對應進行回應。狀態改變提交操作方法。集中存儲中對象的零散數據,全局唯一,以進行統一的狀態管理。 一、前言 當我們的應用遇到多個組件共享狀態時,會需要多個組件依賴于同一狀態抑或是來自不同視圖的行為需要變更同一狀態。以前的解決辦法: a.將數據以及操作...
摘要:寫在前面沒錯,這就是慕課網上的那個音樂播放器,后臺是某音樂播放器的線上接口扒取,雖然這類項目寫的人很多,但不得不說這還是個少有的適合提升的好項目,做這個項目除了想寫一個比較大并且功能復雜的項目,主要原因是要拿它來應對面試,也確實對我的業務能 寫在前面 沒錯,這就是慕課網上的那個vue音樂播放器,后臺是某音樂播放器的線上接口扒取,雖然這類項目寫的人很多,但不得不說這還是個少有的適合vu...
摘要:技術路線的選擇技術學習內容匯總技術路線的選擇項目的技術路線是使用構建一套前端應用,更加具體的技術路線實際上是,應用到了技術棧加上了最新版的。不管怎么說,以這次項目對的使用體驗挺好。本次項目沒有使用開源的要求,自然是最好的選擇。 寫這篇總結的意義:總結,回顧,反思項目進行過程和這套Vue + ArcGIS API for JavaScriptGIS前端應用技術路線,從項目與技術兩個方面積...
閱讀 3792·2023-01-11 11:02
閱讀 4299·2023-01-11 11:02
閱讀 3121·2023-01-11 11:02
閱讀 5231·2023-01-11 11:02
閱讀 4793·2023-01-11 11:02
閱讀 5568·2023-01-11 11:02
閱讀 5371·2023-01-11 11:02
閱讀 4070·2023-01-11 11:02