在Vue2中v-model和.sync區(qū)別解析
在vue2中提供了.sync修飾符,但是在vue3中不再支持.sync,取而代之的是v-model。
1.在vue2中v-model和.sync區(qū)別:
1.相同點:都是語法糖,都可以實現(xiàn)父子組件中的數(shù)據(jù)的雙向通信。
? 區(qū)別在于往回傳值的時候. sync 的 $emit 所調(diào)用的事件名必須是update:屬性名。
2.格式不同:v-model=“num”, :num.sync=“num”
? v-model: @input + value
? :num.sync: @update:num
3.v-model只能用一次;.sync可以有多個
2. .sync修飾符的作用
.sync能夠?qū)崿F(xiàn)屬性間的一個雙向綁定。比如說現(xiàn)在我們有一個這個組件,然后上面有一個v-bind="title"這樣的一個屬性。
如果說寫成v-bind:title.sync="title",那么它可以看做是一個語法糖,它會隱式的向子組件里面?zhèn)鬟f一個v-on:update="title"這樣的一個事件,也就是說
<my-dialog :title.sync="title"></my-dialog>
等價于
<my-dialog :title="title" @update="title=> title = newTitle"></my-dialog>
然后在子組件里面?zhèn)鬟^去調(diào)用$emit(update:title)冒號title來去修改父組件里面所綁定的值。它是能夠?qū)崿F(xiàn)屬性間的一個雙向綁定。
//my-dialog.vue <template> <input :value="title" @update="$emit('update:title', $event.target.value)"/> </template>
官方文檔關(guān)于這部分的參考:https://v2.cn.vuejs.org/v2/guide/components-custom-events.html#sync-%E4%BF%AE%E9%A5%B0%E7%AC%A6
3 問題:v-model只能用于表單組件是嗎?即使用在自定義組件中,子組件里面也必須是表單組件?
v-model在頁面中不只是能用于表單控件<input>, <textarea> and <select>中。除此之前還可以使用到自定義組件中。
父組件使用了v-model以后,自定義組件里面,也不止限于表單組件。v-model其實只是一個語法糖,和子組件是不是表單組件沒有關(guān)系。v-model="name" 其實是其實是v-bind:name="name"和v-on:update="name=>newName=name"的語法縮寫。
比如說,就算是在子組件中input控件可以實現(xiàn)雙綁也是因為使用了:value="name"和@input="$emit('update:name', $event.target.value)",其實是內(nèi)部對這個v-model進行了再次處理。
而對于div等這種,也可以通過$emit()的形式通知父組件然后由父組件對值進行修改。
總得來說就是v-model可以使用在表單或者自定義組件上。但是自定義組件里面的內(nèi)容,針對表單和非表單控件,要做不同的處理才能實現(xiàn)數(shù)據(jù)雙綁。
//父組件 <my-dialog v-model:name="name"></my-dialog> //子組件: <input type="text" :value="name" @input="$emit('update:name', $event.target.value)" /> defineProps(['name']) defineEmits(['update:name'])
4.vue3在自定義組件中的v-model寫法
<CustomInput v-model="searchText"></CustomInput>
等價于:
<CustomInput :model-value="searchText" @update:model-value="newValue => searchText = newValue" />
子組件中:
<!-- CustomInput.vue --> <script setup> defineProps(['modelValue']) defineEmits(['update:modelValue']) </script> <template> <input :value="modelValue" @input="$emit('update:modelValue', $event.target.value)" /> </template>
5.題:vue2中的v-bind:name.sync的用法是不是和vue3中v-model在自定義組件中的用法一樣的?
vue2和vue3中v-model最大的區(qū)別就是對.sync修飾符進行了改寫,v-model中整合了.sync修飾符的功能
<text-document v-bind:title.sync="title"></text-document>
就相當(dāng)于
<text-document v-bind:title="title" v-on:update:title="title = $event" ></text-document>
到此這篇關(guān)于在Vue2中v-model和.sync區(qū)別的文章就介紹到這了,更多相關(guān)vue v-model和.sync區(qū)別內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- vue2和vue3組件v-model區(qū)別詳析
- Vue2子組件綁定 v-model,實現(xiàn)父子組件通信方式
- vue2中如何自定義組件的v-model
- Vue v-model相關(guān)知識總結(jié)
- vue2 v-model/v-text 中使用過濾器的方法示例
- vue 2.0組件與v-model詳解
- Vue2.0利用 v-model 實現(xiàn)組件props雙向綁定的優(yōu)美解決方案
- vue2 如何實現(xiàn)div contenteditable=“true”(類似于v-model)的效果
- vue2與vue3雙向數(shù)據(jù)綁定的區(qū)別說明
- vue 2 實現(xiàn)自定義組件一到多個v-model雙向數(shù)據(jù)綁定的方法(最新推薦)
相關(guān)文章
vue中的事件觸發(fā)(emit)及監(jiān)聽(on)問題
這篇文章主要介紹了vue中的事件觸發(fā)(emit)及監(jiān)聽(on)問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-10-10Vue輸入框?qū)崟r驗證IP地址合法性并在下方進行提示功能實現(xiàn)
在Vue組件中的IP地址輸入框定義一個checkIpAddress方法,該方法使用正則表達式對傳入的IP地址進行驗證,這篇文章主要介紹了Vue輸入框?qū)崟r驗證IP地址合法性并在下方進行提示,需要的朋友可以參考下2024-06-06Vue中l(wèi)ocalStorage的用法和監(jiān)聽localStorage值的變化
這篇文章主要介紹了Vue中l(wèi)ocalStorage的用法和監(jiān)聽localStorage值的變化,本文給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2023-04-04element-ui下拉輸入框+resetFields無法回顯的問題解決
本文主要介紹了在使用Element?UI的下拉輸入框時,點擊重置按鈕后輸入框無法回顯數(shù)據(jù)的問題,具有一定的參考價值,感興趣的可以了解一下2025-01-01Vue實現(xiàn)Base64轉(zhuǎn)png、jpg圖片格式
這篇文章主要給大家介紹了關(guān)于Vue實現(xiàn)Base64轉(zhuǎn)png、jpg圖片格式的相關(guān)資料,前段獲取生成的是base64圖片,需要轉(zhuǎn)化為jpg,png,需要的朋友可以參考下2023-09-09