欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

在Vue2中v-model和.sync區(qū)別解析

 更新時(shí)間:2023年10月26日 14:48:08   作者:_Jyann_  
在vue2中提供了.sync修飾符,但是在vue3中不再支持.sync,取而代之的是v-model,本文給大家介紹在Vue2中v-model和.sync區(qū)別,感興趣的朋友一起看看吧

在vue2中提供了.sync修飾符,但是在vue3中不再支持.sync,取而代之的是v-model。

1.在vue2中v-model和.sync區(qū)別:

1.相同點(diǎn):都是語(yǔ)法糖,都可以實(shí)現(xiàn)父子組件中的數(shù)據(jù)的雙向通信。
? 區(qū)別在于往回傳值的時(shí)候. sync 的 $emit 所調(diào)用的事件名必須是update:屬性名。
2.格式不同:v-model=“num”, :num.sync=“num”
? v-model: @input + value
? :num.sync: @update:num
3.v-model只能用一次;.sync可以有多個(gè)

2. .sync修飾符的作用

.sync能夠?qū)崿F(xiàn)屬性間的一個(gè)雙向綁定。比如說(shuō)現(xiàn)在我們有一個(gè)這個(gè)組件,然后上面有一個(gè)v-bind="title"這樣的一個(gè)屬性。
如果說(shuō)寫(xiě)成v-bind:title.sync="title",那么它可以看做是一個(gè)語(yǔ)法糖,它會(huì)隱式的向子組件里面?zhèn)鬟f一個(gè)v-on:update="title"這樣的一個(gè)事件,也就是說(shuō)

<my-dialog :title.sync="title"></my-dialog>

等價(jià)于

<my-dialog :title="title" @update="title=> title = newTitle"></my-dialog>

然后在子組件里面?zhèn)鬟^(guò)去調(diào)用$emit(update:title)冒號(hào)title來(lái)去修改父組件里面所綁定的值。它是能夠?qū)崿F(xiàn)屬性間的一個(gè)雙向綁定。

//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 問(wèn)題:v-model只能用于表單組件是嗎?即使用在自定義組件中,子組件里面也必須是表單組件?

v-model在頁(yè)面中不只是能用于表單控件<input>, <textarea> and <select>中。除此之前還可以使用到自定義組件中。

父組件使用了v-model以后,自定義組件里面,也不止限于表單組件。v-model其實(shí)只是一個(gè)語(yǔ)法糖,和子組件是不是表單組件沒(méi)有關(guān)系。v-model="name" 其實(shí)是其實(shí)是v-bind:name="name"和v-on:update="name=>newName=name"的語(yǔ)法縮寫(xiě)。
比如說(shuō),就算是在子組件中input控件可以實(shí)現(xiàn)雙綁也是因?yàn)槭褂昧?value="name"和@input="$emit('update:name', $event.target.value)",其實(shí)是內(nèi)部對(duì)這個(gè)v-model進(jìn)行了再次處理。
而對(duì)于div等這種,也可以通過(guò)$emit()的形式通知父組件然后由父組件對(duì)值進(jìn)行修改。
總得來(lái)說(shuō)就是v-model可以使用在表單或者自定義組件上。但是自定義組件里面的內(nèi)容,針對(duì)表單和非表單控件,要做不同的處理才能實(shí)現(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寫(xiě)法

<CustomInput v-model="searchText"></CustomInput>

 等價(jià)于:

<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ū)別就是對(duì).sync修飾符進(jìn)行了改寫(xiě),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)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 詳解Vue.js中的組件傳值機(jī)制

    詳解Vue.js中的組件傳值機(jī)制

    Vue.js 是一款流行的前端框架,它提供了一些方便的機(jī)制來(lái)管理組件之間的通信,其中包括組件傳值,本文將詳細(xì)介紹 Vue.js 中的組件傳值機(jī)制,包括父子組件傳值、兄弟組件傳值、跨級(jí)組件傳值等多種方式,需要的朋友可以參考下
    2023-08-08
  • vue中的事件觸發(fā)(emit)及監(jiān)聽(tīng)(on)問(wèn)題

    vue中的事件觸發(fā)(emit)及監(jiān)聽(tīng)(on)問(wèn)題

    這篇文章主要介紹了vue中的事件觸發(fā)(emit)及監(jiān)聽(tīng)(on)問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-10-10
  • Vue輸入框?qū)崟r(shí)驗(yàn)證IP地址合法性并在下方進(jìn)行提示功能實(shí)現(xiàn)

    Vue輸入框?qū)崟r(shí)驗(yàn)證IP地址合法性并在下方進(jìn)行提示功能實(shí)現(xiàn)

    在Vue組件中的IP地址輸入框定義一個(gè)checkIpAddress方法,該方法使用正則表達(dá)式對(duì)傳入的IP地址進(jìn)行驗(yàn)證,這篇文章主要介紹了Vue輸入框?qū)崟r(shí)驗(yàn)證IP地址合法性并在下方進(jìn)行提示,需要的朋友可以參考下
    2024-06-06
  • Vue.js 的 watch函數(shù)基本用法

    Vue.js 的 watch函數(shù)基本用法

    watch 函數(shù)是 Vue.js 提供的一個(gè)強(qiáng)大工具,用于響應(yīng)數(shù)據(jù)變化并執(zhí)行相應(yīng)的回調(diào),通過(guò)合理使用 watch 函數(shù),我們可以實(shí)現(xiàn)異步數(shù)據(jù)請(qǐng)求、表單驗(yàn)證、動(dòng)態(tài)樣式等多種功能,這篇文章主要介紹了Vue.js 的 watch函數(shù),需要的朋友可以參考下
    2024-08-08
  • 使用vue組件封裝共用的組件

    使用vue組件封裝共用的組件

    這篇文章主要介紹了使用vue組件封裝共用的組件,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-05-05
  • Vue中l(wèi)ocalStorage的用法和監(jiān)聽(tīng)localStorage值的變化

    Vue中l(wèi)ocalStorage的用法和監(jiān)聽(tīng)localStorage值的變化

    這篇文章主要介紹了Vue中l(wèi)ocalStorage的用法和監(jiān)聽(tīng)localStorage值的變化,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2023-04-04
  • 如何在Vue中使用debouce防抖函數(shù)

    如何在Vue中使用debouce防抖函數(shù)

    本文主要介紹在Vue中使用debouce防抖函數(shù),設(shè)置一個(gè)門(mén)檻值,表示兩次?Ajax?通信的最小間隔時(shí)間。如果在間隔時(shí)間內(nèi),發(fā)生新的keydown事件,則不觸發(fā)?Ajax?通信,并且重新開(kāi)始計(jì)時(shí)。如果過(guò)了指定時(shí)間,沒(méi)有發(fā)生新的keydown事件再將數(shù)據(jù)發(fā)送出去,這便是debouce防抖函數(shù)
    2021-12-12
  • element-ui下拉輸入框+resetFields無(wú)法回顯的問(wèn)題解決

    element-ui下拉輸入框+resetFields無(wú)法回顯的問(wèn)題解決

    本文主要介紹了在使用Element?UI的下拉輸入框時(shí),點(diǎn)擊重置按鈕后輸入框無(wú)法回顯數(shù)據(jù)的問(wèn)題,具有一定的參考價(jià)值,感興趣的可以了解一下
    2025-01-01
  • Vue實(shí)現(xiàn)Base64轉(zhuǎn)png、jpg圖片格式

    Vue實(shí)現(xiàn)Base64轉(zhuǎn)png、jpg圖片格式

    這篇文章主要給大家介紹了關(guān)于Vue實(shí)現(xiàn)Base64轉(zhuǎn)png、jpg圖片格式的相關(guān)資料,前段獲取生成的是base64圖片,需要轉(zhuǎn)化為jpg,png,需要的朋友可以參考下
    2023-09-09
  • 記一次用vue做的活動(dòng)頁(yè)的方法步驟

    記一次用vue做的活動(dòng)頁(yè)的方法步驟

    這篇文章主要介紹了記一次用vue做的活動(dòng)頁(yè)的方法步驟,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-04-04

最新評(píng)論