javascript - vue中更改state的值
問(wèn)題描述
我知道 actions 是處理異步的 我沒(méi)有異步操作 我的意思是 點(diǎn)擊一個(gè)按鈕之后 在methods 中直接更改state中的值 ,不通過(guò)actions 也不通過(guò)mutation 這樣符合vue的規(guī)范嗎
問(wèn)題解答
回答1:關(guān)于為什么不能直接調(diào)用mutation方法或者直接修改state屬性,而是必須得通過(guò)commit來(lái)提交mutation呢?引用官方文檔:
再次強(qiáng)調(diào),我們通過(guò)提交 mutation 的方式,而非直接改變 store.state.count,是因?yàn)槲覀兿胍鞔_地追蹤到狀態(tài)的變化。這個(gè)簡(jiǎn)單的約定能夠讓你的意圖更加明顯,這樣你在閱讀代碼的時(shí)候能更容易地解讀應(yīng)用內(nèi)部的狀態(tài)改變。此外,這樣也讓我們有機(jī)會(huì)去實(shí)現(xiàn)一些能記錄每次狀態(tài)改變,保存狀態(tài)快照的調(diào)試工具。有了它,我們甚至可以實(shí)現(xiàn)如時(shí)間穿梭般的調(diào)試體驗(yàn)。由于 store 中的狀態(tài)是響應(yīng)式的,在組件中調(diào)用 store 中的狀態(tài)簡(jiǎn)單到僅需要在計(jì)算屬性中返回即可。觸發(fā)變化也僅僅是在組件的 methods 中提交 mutations。
可以看出來(lái)實(shí)際上是設(shè)計(jì)vuex的時(shí)候?yàn)榱俗粉檚tate的變化,約定一定要用commit去提交mutation觸發(fā)數(shù)據(jù)的變化的。你可以試一下官方的vue調(diào)試插件,叫Vue Devtools,可以直接看到組件,data,vuex等,也可以追蹤變化什么的,試一下估計(jì)你就知道為什么要這么做了。
相關(guān)文章:
1. docker安裝后出現(xiàn)Cannot connect to the Docker daemon.2. 為什么我ping不通我的docker容器呢???3. android - webview 自定義加載進(jìn)度條4. mysql - 怎么讓 SELECT 1+null 等于 15. javascript - 微信音樂(lè)分享6. 網(wǎng)頁(yè)爬蟲(chóng) - 用Python3的requests庫(kù)模擬登陸B(tài)ilibili總是提示驗(yàn)證碼錯(cuò)誤怎么辦?7. javascript - 微信小程序封裝定位問(wèn)題(封裝異步并可能多次請(qǐng)求)8. 并發(fā)模型 - python將進(jìn)程池放在裝飾器里為什么不生效也沒(méi)報(bào)錯(cuò)9. linux - openSUSE 上,如何使用 QQ?10. python 怎樣用pickle保存類(lèi)的實(shí)例?
