vue修飾符v-model及.sync原理及區(qū)別詳解
v-model的原理
- v-model的本質(zhì),其實就是
:value和@input事件的語法糖
<!--v-model寫法-->
<my-component type="text" v-model="num">
<!--展開語法糖后的寫法-->
<my-component type="text"
:value="num"
@input="(value) => num = value"
>
父組件通過向子組件傳值和自定義事件,子組件里面通過$emit去觸發(fā)input事件
- 注意點: 在子組件中 這個input事件是自定義事件
// 在子組件中
<template lang="">
<div>
<div>{{ num }}</div>
<button @click="$emit('input',num + 1)"></button>
</div>
</template>
<script>
export default {
props:{
num:{
type: Number,
required: true
}
}
}
.sync的原理
// 在父組件中
<my-component :value.sync="num" />
// 子組件中
<template lang="">
<div>
<div>{{ num }}</div>
<button @click="$emit('update:value',num + 1)"></button>
</div>
</template>
<script>
export default {
props:{
num:{
type: Number,
required: true
}
}
}
兩者本質(zhì)都是一樣,并沒有任何區(qū)別: “監(jiān)聽一個觸發(fā)事件”="(val) => value = val"。
v-model和.sync修飾符的區(qū)別
.sync與v-model區(qū)別是
相同點:都是語法糖,都可以實現(xiàn)父子組件中的數(shù)據(jù)的雙向通信。
區(qū)別點:
- 格式不同。 v-model="num", :num.sync="num"
- v-model: @input + value
- :num.sync: @update:num
- v-model只能用一次;.sync可以有多個。
只不過v-model默認對應的是input或者textarea等組件的input事件,如果在子組件替換這個input事件,其本質(zhì)和.sync修飾符一模一樣。比較單一,不能有多個。
// 子組件可以用自定義事件,來替換v-model默認對應的原生input事件,只不過我們需要在子組件手動 $emit
model: {
prop: "value",
event: "update"
},
一個組件可以多個屬性用.sync修飾符,可以同時"雙向綁定多個“prop”,而并不像v-model那樣,一個組件只能有一個。
因為使用v-model,子組件中只能觸發(fā)一個input事件,事件名是唯一的,而.sync修飾符,它觸發(fā)的時間名是updata:屬性名,所以它有多個事件名,就可以使用多次
總結(jié)作用場景:
- props/$emit是父子組件最常用的通信方式,而v-model、.sync只是其語法糖
- 子組件只是單一的修改某個父組件值的話,表單類組件使用
v-model語法糖 - 子組件只是單一的修改某個父組件值的話,非表單類組件使用
sync語法糖 - 復雜邏輯還是老老實實
props/$emit
其實語法糖只是在父組件用的時候更加方便,而子組件該咋樣還是咋樣。
以上就是vue修飾符v-model及.sync原理及區(qū)別詳解的詳細內(nèi)容,更多關于vue修飾符v-model .sync的資料請關注腳本之家其它相關文章!
相關文章
vue?Proxy數(shù)據(jù)代理進行校驗部分源碼實例解析
Proxy提供了強大的Javascript元編程,有許多功能,包括運算符重載,對象模擬,簡潔而靈活的API創(chuàng)建,對象變化事件,甚至Vue 3背后的內(nèi)部響應系統(tǒng)提供動力,這篇文章主要給大家介紹了關于vue?Proxy數(shù)據(jù)代理進行校驗部分源碼解析的相關資料,需要的朋友可以參考下2022-01-01
vue-admin-template?動態(tài)路由的實現(xiàn)示例
本文主要介紹了ue-admin-template動態(tài)路由的實現(xiàn),文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2021-12-12
vue項目打包后,由于html被緩存導致出現(xiàn)白屏的處理方案
這篇文章主要介紹了vue項目打包后,由于html被緩存導致出現(xiàn)白屏的處理方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-03-03
Vue + Webpack + Vue-loader學習教程之相關配置篇
這篇文章主要介紹了關于Vue + Webpack + Vue-loader的相關配置篇,文中通過示例代碼介紹的非常詳細,相信對大家具有一定的參考價值,需要的朋友們下面來一起看看吧。2017-03-03
SyntaxError:?/xx.vue:?Unexpected?token,?expected?“,“錯誤解
這篇文章主要為大家介紹了SyntaxError:?/xx.vue:?Unexpected?token,?expected?“,“錯誤解決方法詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-08-08

