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

vue中v-model和.sync修飾符的區(qū)別

 更新時間:2022年06月08日 15:56:31   作者:前端小解不懈  
在平時開發(fā)是經(jīng)常用到一些父子組件通信,經(jīng)常用到props、vuex等等,下面這篇文章主要給大家介紹了關(guān)于vue中v-model和.sync修飾符區(qū)別的相關(guān)資料,需要的朋友可以參考下

前言

在日常開發(fā)的過程中,v-model指令是經(jīng)常用到的,一般來說 v-model 指令在表單元素上創(chuàng)建雙向數(shù)據(jù)綁定,但 v-model 本質(zhì)是語法糖。但提到語法糖,這里就不得不提另一個與v-model有相似功能的雙向綁定語法糖了,這就是 .sync修飾符。在這里就兩者的使用進行一下總結(jié):

一、v-model

1. 作用

相信使用過vue框架的朋友對這個指令不會感到陌生,v-model是用來進行<input>、<textarea>及 <select> 元素上數(shù)據(jù)的雙向綁定的
例如:

<template>
 <div>
   <input v-model="value" type="text">   //這里的v-model里面的value可以直接獲取到用戶的輸入值
 </div>
</template>

<script>
import son from '@/yanshi/son.vue'
 data() {
   return {
     value: ''    //這里定義的value變量可以直接將上面獲取到的值進行操作
   }
 }
}
</script>

當(dāng)我們在input輸入框里面輸入了某個在值的時候,下面就可以直接獲取到我們的輸入值,而不需要操作dom元素進行獲取

2.v-model的本質(zhì)

v-model的本質(zhì)上來說,是一個語法糖

目前咱們習(xí)慣性的寫法是這樣的:

<input v-model="val" type="text">

但是實質(zhì)上的完整寫法:

<input :value="val"  @input="val=$event.target.value" />

也可以將@input后面寫成一個函數(shù),然后在methods中進行賦值操作。

要理解這行代碼,首先你要知道 input 元素本身有個input 事件,這是 HTML5 新增加的,類似 onchange ,每當(dāng)輸入框內(nèi)容發(fā)生變化,就會觸發(fā) input 事件,把最新的value值傳給傳遞給val ,完成雙向數(shù)據(jù)綁定的效果 。

我們仔細觀察語法糖和原始語法那兩行代碼,可以得出一個結(jié)論:

在給 <input />元素添加 v-model 屬性時,默認會把 val作為元素的屬性,然后把input事件作為實時傳遞 value 的觸發(fā)事件

注意:  不是所有能進行雙向綁定的元素都是input事件。

3. v-model的特殊用法

一般情況,咱們使用v-model主要是用于數(shù)據(jù)的雙向綁定,可以十分方便的獲取到用戶的輸入值。但在某些特殊情況下,我們也可以將v-model用于父子組件之間數(shù)據(jù)的雙向綁定。這里需要用到父子傳值的相關(guān)知識:

<template>
  <div>
    <son  v-model="num"/> //使用子組件
  </div>
</template>

<script>
import son from '@/yanshi/son.vue'   //引入子組件
export default {
  components: {
    son    //注冊子組件
  },
  data() {
    return {
      num: 100
    }
  }
}
</script>

這里咱們先定義了一個father組件和一個son組件,并且將son組件引入到father組件中,并且給son組件綁定了v-model進行了傳值。此時,我們需要到son組件中接收這個值并且使用他:

<template>
  <div>
    我是son組件里面接收到的值: {{ value }}
  </div>
</template>

<script>
export default {
  props: {
    value: {
      type: Number,
      required: true
    }
  }
}
</script>

注意:  我們這里接收的值必須是value,寫成其他名字將無法使用

一般情況下的父向子傳值,子組件中是不能直接修改的,在這里我們在子組件中直接修改這個值會進行報錯

例如:

<template>
  <div>
    我是son組件里面接收到的值: {{ value }}
    <button @click="value+=1">點我value+1</button>  
  </div>
</template>

錯誤信息

當(dāng)我們需要將修改這個值時,就需要再將其傳入父組件進行修改。

這就需要在父組件的子組件標(biāo)簽上定義一個自定義的事件,通過在子組件中使用$emit('自定義事件名',值)的方法將值傳入父組件

在這里我們不能使用自定義的事件,因為我們用的是v-model進行的傳值,所以我們只能使用input事件進行修改

父組件中定義一個@input方法,再設(shè)置一個形參val接收子組件的傳值,

<template>
  <div>
    {{ num }}
    <son v-model="num" @input="val=>num=val" />
  </div>
</template>

子組件中使用$emit()方法.調(diào)用父組件中的事件,并且進行傳值

<template>
  <div>
    我是son組件里面接收到的值: {{ value }}
    <button @click="$emit('input',value+1)">點我value+1</button>
  </div>
</template>

這樣的話,就可以完成父子組件之間的數(shù)據(jù)雙向綁定效果,并且不會出現(xiàn)報錯

二、.sync修飾符

1. .sync修飾符作用

相比較與v-model來說,sync修飾符就簡單很多了:

.sync修飾符可以實現(xiàn)子組件與父組件的雙向綁定,并且可以實現(xiàn)子組件同步修改父組件的值。

2. .sync修飾符本質(zhì)

// 正常父傳子: 
<son :a="num" :b="num2"></son>

// 加上sync之后父傳子: 
<son :a.sync="num" .b.sync="num2"></son> 

// 它等價于
<son
  :a="num" @update:a="val=>num=val"
  :b="num2" @update:b="val=>num2=val"></son> 

// 相當(dāng)于多了一個事件監(jiān)聽,事件名是update:a,回調(diào)函數(shù)中,會把接收到的值賦值給屬性綁定的數(shù)據(jù)項中。

這里面的傳值與接收與正常的父向子傳值沒有區(qū)別,唯一的區(qū)別在于往回傳值的時候$emit所調(diào)用的事件名必須是update:屬性名 ,事件名寫錯不會報錯,但是也不會有任何的改變,這點需要多注意。

總結(jié)

.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可以有多個。

到此這篇關(guān)于vue中v-model和.sync修飾符區(qū)別的文章就介紹到這了,更多相關(guān)v-model和.sync修飾符區(qū)別內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • vue2.0 下拉框默認標(biāo)題設(shè)置方法

    vue2.0 下拉框默認標(biāo)題設(shè)置方法

    今天小編就為大家分享一篇vue2.0 下拉框默認標(biāo)題設(shè)置方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-08-08
  • vue中element-ui使用axios上傳文件

    vue中element-ui使用axios上傳文件

    這篇文章主要為大家詳細介紹了vue中element-ui使用axios上傳文件,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-08-08
  • vue3+Typescript實現(xiàn)路由標(biāo)簽頁和面包屑功能

    vue3+Typescript實現(xiàn)路由標(biāo)簽頁和面包屑功能

    在使用 Vue.js 開發(fā)后臺管理系統(tǒng)時,經(jīng)常會遇到需要使用路由標(biāo)簽頁的場景,這篇文章主要介紹了vue3+Typescript實現(xiàn)路由標(biāo)簽頁和面包屑,需要的朋友可以參考下
    2023-05-05
  • vue+koa2搭建mock數(shù)據(jù)環(huán)境的詳細教程

    vue+koa2搭建mock數(shù)據(jù)環(huán)境的詳細教程

    這篇文章主要介紹了vue+koa2搭建mock數(shù)據(jù)環(huán)境的方法,本文通過實例代碼給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-05-05
  • Vue中實現(xiàn)權(quán)限控制的方法示例

    Vue中實現(xiàn)權(quán)限控制的方法示例

    這篇文章主要介紹了Vue中實現(xiàn)權(quán)限控制的方法示例,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2019-06-06
  • Vue.js教程之a(chǎn)xios與網(wǎng)絡(luò)傳輸?shù)膶W(xué)習(xí)實踐

    Vue.js教程之a(chǎn)xios與網(wǎng)絡(luò)傳輸?shù)膶W(xué)習(xí)實踐

    這篇文章主要給大家介紹了Vue.js之a(chǎn)xios與網(wǎng)絡(luò)傳輸?shù)南嚓P(guān)資料,文中介紹的非常詳細,對大家具有一定的參考學(xué)習(xí)價值,需要的朋友們下面跟隨小編一起來學(xué)習(xí)學(xué)習(xí)吧。
    2017-04-04
  • 學(xué)習(xí)Vite的原理

    學(xué)習(xí)Vite的原理

    這篇文章主要介紹了Vite的原理,Vite是一個更輕、更快的web應(yīng)用開發(fā)工具,面向現(xiàn)代瀏覽,Vite創(chuàng)建的項目是一個普通的Vue3應(yīng)用,相比基于Vue-cli創(chuàng)建的應(yīng)用少了很多配置文件和依賴,下面基于Vite相關(guān)資料內(nèi)容,需要的朋友可以參考一下
    2022-02-02
  • 使用vue3.2實現(xiàn)多頁簽導(dǎo)航

    使用vue3.2實現(xiàn)多頁簽導(dǎo)航

    這篇文章主要為大家詳細介紹了如何使用vue3.2 + elementPlus + pinia 實現(xiàn)多頁簽導(dǎo)航,文中的示例代碼講解詳細,有需要的小伙伴可以參考一下
    2023-12-12
  • vue實現(xiàn)原理this.$message實例詳解

    vue實現(xiàn)原理this.$message實例詳解

    這篇文章主要介紹了vue實現(xiàn)原理this.$message實例詳解,本文通過實例代碼給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友參考下吧
    2024-03-03
  • 詳解vuex狀態(tài)管理模式

    詳解vuex狀態(tài)管理模式

    這篇文章主要介紹了詳解vuex狀態(tài)管理模式,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-11-11

最新評論