詳解vuex commit保存數(shù)據(jù)技巧
vuex 單向數(shù)據(jù)流,推薦的commit 改變state數(shù)據(jù),寫起來非常繁瑣,因為改數(shù)據(jù)可能要寫很多commit函數(shù)。
依據(jù)我的理解,單向數(shù)據(jù)流主要是為了避免數(shù)據(jù)混亂,便于調(diào)試。 說白了,就是一個數(shù)據(jù)改變了,是什么促使他改變的。
數(shù)據(jù)流向永遠都是一個方向,下游是沒有權(quán)利改變數(shù)據(jù)的,所以需要數(shù)據(jù)發(fā)放中心同一級的方法來改變數(shù)據(jù)。
單項數(shù)據(jù)流,對于react來說,的確是必要的,但對于vue來說,是那么有必要嗎?
vue采用數(shù)據(jù)依賴更新,必要的數(shù)據(jù)都采用Object.defineProperty處理。給數(shù)據(jù)賦值時,本來就會通知所有采用此數(shù)據(jù)的dom更新,不管是不是父級還是子級組建的dom。
使用vuex時 官方推薦使用commit才修改state數(shù)據(jù)。
優(yōu)點
- 便于調(diào)試,當數(shù)據(jù)變化時,可以在vuetools工具中看到是哪個函數(shù)修改了state值。
缺點
- 采用commit修改數(shù)據(jù),可能會寫很多mutations函數(shù)。
- 會上喪失掉一部分性能。因為新數(shù)據(jù)需要重新配置watcher。
優(yōu)化
對于采用commit保存state數(shù)據(jù)的,可以采用如下方式:
傳一個字符串的path和需要修改的值,如果path='a.b.c'就換算成 state.a.b.c = 'needsave', 這就達到了一個commit 解決所有保存的問題。
// mutations中的函數(shù)
save(state, { path, data }) {
if (!path ) {
throw new Error('need path')
}
const keyPath = path.split('.')
let needSave = state
for (let i = 0; i < keyPath.length - 1; i++) {
needSave = needSave[keyPath[i]]
if(!needSave) {
throw new Error(`error path: ${keyPath[i]}`)
}
}
needSave[keyPath[keyPath.length - 1]] = data
},
// 使用
vuex.commit('save', {path:'a.b.c', data:val})
// 結(jié)果
state.a.b.c = '我是需要保存的數(shù)據(jù)'
在組件中
//如果要雙向綁定某個vuex中的值。
<input v-model="c">
//script
computed: {
c: {
get(){
return vuex.state.a.b.c
},
set(val) {
vuex.commit('save', {path:'a.b.c', data:val})
}
}
}
// 這樣就做到了在組件中雙向綁定,并且使用commit改變state中的值,vuex使用嚴格模式也不會報錯了。
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
vuejs動態(tài)組件給子組件傳遞數(shù)據(jù)的方法詳解
這篇文章主要介紹了vuejs動態(tài)組件給子組件傳遞數(shù)據(jù)的方法詳解的相關(guān)資料,需要的朋友可以參考下2016-09-09
解決ant design vue 表格a-table二次封裝,slots渲染的問題
這篇文章主要介紹了解決ant design vue 表格a-table二次封裝,slots渲染的問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-10-10
vue截圖轉(zhuǎn)base64轉(zhuǎn)文件File異步獲取方式
這篇文章主要介紹了vue截圖轉(zhuǎn)base64轉(zhuǎn)文件File異步獲取方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-03-03
vue報錯Failed to execute 'appendChild&apos
這篇文章主要為大家介紹了vue報錯Failed to execute 'appendChild' on 'Node'解決方法詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2022-11-11
vue中的get方法\post方法如何實現(xiàn)傳遞數(shù)組參數(shù)
這篇文章主要介紹了vue中的get方法\post方法如何實現(xiàn)傳遞數(shù)組參數(shù),具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-04-04

