vue單向數(shù)據(jù)流的深入理解
官網(wǎng)解釋
所有的 prop 都使得其父子 prop 之間形成了一個單向下行綁定:父級 prop 的更新會向下流動到子組件中,但是反過來則不行。這樣會防止從子組件意外變更父級組件的狀態(tài),從而導致你的應(yīng)用的數(shù)據(jù)流向難以理解。額外的,每次父級組件發(fā)生變更時,子組件中所有的 prop 都將會刷新為最新的值。這意味著你不應(yīng)該在一個子組件內(nèi)部改變 prop。如果你這樣做了,Vue 會在瀏覽器的控制臺中發(fā)出警告。
單向數(shù)據(jù)流是什么
單向數(shù)據(jù)流指只能從一個方向來修改狀態(tài)。下圖是單向數(shù)據(jù)流的極簡示意:
與單向數(shù)據(jù)流對對應(yīng)的是雙向數(shù)據(jù)流(也叫雙向綁定)。在雙向數(shù)據(jù)流中,Model(可以理解為狀態(tài)的集合) 中可以修改自己或其他Model的狀態(tài), 用戶的操作(如在輸入框中輸入內(nèi)容)也可以修改狀態(tài)。這使改變一個狀態(tài)有可能會觸發(fā)一連串的狀態(tài)的變化,最后很難預測最終的狀態(tài)是什么樣的。使得代碼變得很難調(diào)試。如下圖所示:

與雙向數(shù)據(jù)流比,在單向數(shù)據(jù)流中,當你需要修改狀態(tài),完全重新開始走一個修改的流程。這限制了狀態(tài)修改的方式,讓狀態(tài)變得可預測,容易調(diào)試。
示例
我們通過一個示例來解釋單向數(shù)據(jù)流與雙向綁定,這個示例是對ant-design-vue表單組件的二次封裝
a-input原始用法
<template>
<a-input v-model='data'/>
</template>
<script>
export default {
data() {
return {
data: ''
}
}
}
</script>在data中聲明的屬性會通過Object.definePropty方法為其添加get和set方法,使其成為響應(yīng)式數(shù)據(jù)。v-model是一個語法糖,在vue 2.2.0版本后新增了model屬性
官方解釋
允許一個自定義組件在使用 v-model 時定制 prop 和 event。默認情況下,一個組件上的 v-model 會把 value 用作 prop 且把 input 用作 event,但是一些輸入類型比如單選框和復選框按鈕可能想使用 value prop 來達到不同的目的。使用 model 選項可以回避這些情況產(chǎn)生的沖突。
我們利用這個屬性來對上述input組件做二次封裝
組件代碼
<template>
<a-input :value='currentValue' @change='onInputChange'/>
</template>
<script>
export default {
data() {
return {
currentValue: this.value
}
},
model: {
event: 'change',
prop: 'value'
},
props:{
value: {
type: String
}
},
watch: {
value: {
handler(newVal) {
this.currentValue = newVal
}
}
},
onInputChange(e) {
this.$emit('change', e.target.value)
}
}
</script>在父組件中使用
<template>
<my-input v-model='data' />
</template>
<script>
export default {
data() {
return {
data:''
}
}
}
</script>上述子組件中的currentValue是實際input組件的值,他的值是根據(jù)父組件傳入的值得出的,input標簽組件的change事件來觸發(fā)父組件的change事件,從而改變傳入子組件props中value的值。這就解釋了單項數(shù)據(jù)流,父組件通過props向子組件傳遞值,子組件通過emit事件來通知父組件修改值,子組件不在自身對父組件傳遞過來的props做任何修改,都是通過父組件來更新props,從而達到子組件更新自身狀態(tài)。
使用場景
當我們在實現(xiàn)一個由數(shù)據(jù)渲染的復雜表單時,那么我們的設(shè)計就可以采用這種模式,通過props以及emit傳遞,保證子組件的事件觸發(fā)根節(jié)點的數(shù)據(jù)更新,從而更新子孫組件的狀態(tài)。
總結(jié)
到此這篇關(guān)于vue單向數(shù)據(jù)流的文章就介紹到這了,更多相關(guān)vue單向數(shù)據(jù)流內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
elementui實現(xiàn)標簽頁與菜單欄聯(lián)動的示例代碼
多級聯(lián)動是一種常見的交互方式,本文主要介紹了elementui實現(xiàn)標簽頁與菜單欄聯(lián)動的示例代碼,具有一定的參考價值,感興趣的可以了解一下2024-06-06
如何解決element-ui動態(tài)加載級聯(lián)選擇器默認選中問題
這篇文章主要介紹了如何解決element-ui動態(tài)加載級聯(lián)選擇器默認選中問題,文章圍繞主題展開詳細的內(nèi)容介紹,具有一定的參考價值,需要的朋友可以參考一下2022-09-09
淺談element中InfiniteScroll按需引入的一點注意事項
這篇文章主要介紹了淺談element中InfiniteScroll按需引入的一點注意事項,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2020-06-06

