国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

一篇看懂vuejs的狀態(tài)管理神器 vuex狀態(tài)管理模式

2019-11-19 16:46:52
字體:
供稿:網(wǎng)友

關于vuex類的新聞最近很多,看到眼熱就去查了下資料,然后扯出來一堆flux、redux、state、state之類的概念,以及大型工程必要性之類的。看官方手冊也是昏昏然。

然而,我還是弄懂了!我準備從demo出發(fā),以同樣的一個最簡單的demo,演示兩種情況下的代碼編寫情況:

  • 單純依賴于vue.js
  • 依賴vue.js,也使用了vuex技術(shù)

目的是通過對比引出vuex的概念、優(yōu)勢和劣勢。也許這是目前最接地氣的vuex的介紹吧:)。所以無論如何在了解vuex之前,你必須懂得vue.js(好像廢話:)。現(xiàn)在開始。

假設一個微小的應用,有一個標簽顯示數(shù)字,兩個按鈕分別做數(shù)字的加一和減一的操作。用戶界面看起來是這樣的:

使用vue的話,就是這樣:

<script src="https://unpkg.com/vue/dist/vue.js"></script><div id="app"> <p>{{count}} <button @click="inc">+</button> <button @click="dec">-</button> </p></div><script>new Vue({ el:'#app', data () { return {  count: 0 } }, methods: { inc () {  this.count++ }, dec () {  this.count-- } }})</script>

我寫的代碼代碼可以直接拷貝到你的html內(nèi)并且打開執(zhí)行,你可以不費多余的勁兒,就把應用跑起來,按按按鈕,看看界面上的反應是否如你預期。

整個代碼結(jié)構(gòu)非常清晰,代碼是代碼,數(shù)據(jù)是數(shù)據(jù),這也是我一直以來非常喜歡vue.js的重要原因。代碼就是放在methods數(shù)組內(nèi)的兩個函數(shù)inc、dec,被指令@click關聯(lián)到button上。而data內(nèi)返回一個屬性count,此屬性通過{{count}}綁定到標簽p內(nèi)。

現(xiàn)在來看看,同樣的demo app,使用vuex完成的代碼的樣子,再一次,如下代碼不是代碼片段,是可以貼入到你的html文件內(nèi),并且直接使用瀏覽器打開運行的。

<script src="https://unpkg.com/vue/dist/vue.js"></script><script src="https://unpkg.com/vuex@next"></script><div id="app"> <p>{{count}} <button @click="inc">+</button> <button @click="dec">-</button> </p></div><script>const store = new Vuex.Store({ state: { count: 0 }, mutations: {  inc: state => state.count++, dec: state => state.count-- }})const app = new Vue({ el: '#app', computed: { count () {  return store.state.count } }, methods: { inc () {  store.commit('inc') }, dec () {  store.commit('dec') } }})</script>

我們先看到有哪些重要的變化:

  • 新的代碼添加了對vuex@next腳本的依賴。這是當然的,因為你需要使用vuex的技術(shù),當然需要引用它
  • methods數(shù)組還是這兩個方法,這和demo1是一樣的;但是方法內(nèi)的計算邏輯,不再是在函數(shù)內(nèi)進行,而是提交給store對象!這是一個新的對象!
  • count數(shù)據(jù)也不再是一個data函數(shù)返回的對象的屬性;而是通過計算字段來返回,并且在計算字段內(nèi)的代碼也不是自己算的,而是轉(zhuǎn)發(fā)給store對象。再一次store對象!

就是說,之前在vue實例內(nèi)做的操作和數(shù)據(jù)的計算現(xiàn)在都不再自己做了,而是交由對象store來做了。這突然讓我想到就先餐廳現(xiàn)在都不在洗碗了,都交給政府認證的機構(gòu)來洗了。

說回正題。store對象是Vuex.Store的實例。在store內(nèi)有分為state對象和mutations對象,其中的state放置狀態(tài),mutations則是一個會引發(fā)狀態(tài)改變的所有方法。正如我們看到的,目前的state對象,其中的狀態(tài)就只有一個count。而mutations有兩個成員,它們參數(shù)為state,在函數(shù)體內(nèi)對state內(nèi)的count成員做加1和減1的操作。

活還是那些活,現(xiàn)在引入了一個store對象,把數(shù)據(jù)更新的活給攬過去,不再需要vue實例自己計算了,代價是引入了新的概念和層次。那么好處是什么(一個土耳其古老的發(fā)問)?

vuex解決了組件之間共享同一狀態(tài)的麻煩問題。當我們的應用遇到多個組件共享狀態(tài)時,會需要:

  • 多個組件依賴于同一狀態(tài)。傳參的方法對于多層嵌套的組件將會非常繁瑣,并且對于兄弟組件間的狀態(tài)傳遞無能為力。這需要你去學習下,vue編碼中多個組件之間的通訊的做法。
  • 來自不同組件的行為需要變更同一狀態(tài)。我們經(jīng)常會采用父子組件直接引用或者通過事件來變更和同步狀態(tài)的多份拷貝。

以上的這些模式非常脆弱,通常會導致無法維護的代碼。來自官網(wǎng)的一句話:Vuex 是一個專為 Vue.js 應用程序開發(fā)的狀態(tài)管理模式。它采用集中式存儲管理應用的所有組件的狀態(tài)。這里的關鍵在于集中式存儲管理。這意味著本來需要共享狀態(tài)的更新是需要組件之間通訊的,而現(xiàn)在有了vuex,就組件就都和store通訊了。問題就自然解決了。

這就是為什么官網(wǎng)再次會提到Vuex構(gòu)建大型應用的價值。如果您不打算開發(fā)大型單頁應用,使用 Vuex 可能是繁瑣冗余的。確實是如此――如果您的應用夠簡單,您最好不要使用 Vuex。

關于

作者:劉傳君

創(chuàng)建過產(chǎn)品,創(chuàng)過業(yè)。好讀書,求甚解。 可以通過 1000copy#gmail.com 聯(lián)系到我

出品

bootstrap小書 https://www.gitbook.com/book/1000copy/bootstrap/details
http小書 http://www.ituring.com.cn/book/1791
Git小書 http://www.ituring.com.cn/book/1870

以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持武林網(wǎng)。

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 祁东县| 南阳市| 浦北县| 新源县| 兰坪| 樟树市| 山东| 林周县| 龙川县| 桑植县| 兴国县| 沁阳市| 全南县| 西青区| 台中县| 云南省| 大悟县| 和龙市| 福海县| 札达县| 新余市| 郁南县| 油尖旺区| 白玉县| 南漳县| 崇州市| 商洛市| 米林县| 邵武市| 准格尔旗| 固始县| 泰和县| 景泰县| 江津市| 邹城市| 杂多县| 西吉县| 丰都县| 兰溪市| 苍南县| 临猗县|