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

vue3自定義組件之v-model實現(xiàn)父子組件雙向綁定

 更新時間:2022年08月09日 10:08:13   作者:Mosowe  
這篇文章主要介紹了vue3自定義組件之v-model實現(xiàn)父子組件雙向綁定方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教

vue3 v-model父子組件雙向綁定

vue3.x移除了vue2.x的model選項,自定義組件雙向綁定不在使用以下方法:

// vue2的v-model雙向綁定方法
model: {
? ? ?prop: 'value', //3.x默認值改為了modelValue
? ? ?event: 'input' //3.x默認值改為了update:modelValue
? ?},
//使用 this.$emit('input', index);

vue3.x采用以下方式(v-model默認對應(yīng)的prop值是modelValue)

父組件:

<inpageMenus
?? ?v-model="menu"
?? ?/>

子組件:

<script>
export default {
? name: 'MenusComponent',
? props: {
? ? modelValue: {
? ? ? type: Number,
? ? ? default: 0,
? ? },
? },
? methods: {
? ? clickMenu(index) {
? ? ? this.$emit('update:modelValue', index);
? ? },
? },
};
</script>

vue3.x可以綁定多個v-model

父組件:

<inpageMenus
?? ?v-model="menu"
?? ?v-model:text="text"
?? ?/>

子組件:

<script>
export default {
? name: 'MenusComponent',
? props: {
? ? modelValue: {
? ? ? type: Number,
? ? ? default: 0,
? ? },
? ? text: {
? ? ? type: String,
? ? ? default: '0',
? ? },
? },
? methods: {
? ? clickMenu(index) {
? ? ? this.$emit('update:modelValue', index);
? ? },
? ? textChange(str) {
? ? ? this.$emit('update:text', str);
? ? },
? },
};
</script>

vue3.x去掉了v-model的.sync修飾符

其他的比如.trim依然可以使用,新增自定義修飾符

父組件

? ? <test
? ? ? v-model.toLowerCase="color"
? ? ? v-model:text.toUpperCase="textValue"/>

子組件 

<template>
? <div class='test'>
? ? <input type="text" @input="inputf">
? ? <input type="text" @input="input2f">
? </div>
</template>
<script>
export default {
? name: 'test',
? props: {
? ? modelValue: {
? ? ? type: String,
? ? ? default: 'eee',
? ? },
? ? modelModifiers: { // 獲取modelValue修飾符
? ? ? type: Object,
? ? ? default: () => ({}),
? ? },
? ? text: {
? ? ? type: String,
? ? ? default: 'eee',
? ? },
? ? textModifiers: { // 獲取text修飾符
? ? ? type: Object,
? ? ? default: () => ({}),
? ? },
? },
? methods: {
? ? inputf(e) {
? ? ? let { value } = e.target;
? ? ? if (this.modelModifiers.toLowerCase) {
? ? ? ? value = value.toLowerCase();
? ? ? }
? ? ? this.$emit('update:modelValue', value);
? ? },
? ? input2f(e) {
? ? ? let { value } = e.target;
? ? ? if (this.textModifiers.toUpperCase) {
? ? ? ? value = value.toUpperCase();
? ? ? }
? ? ? this.$emit('update:text', value);
? ? },
? },
};
</script>

vue3 v-model使用(多個 v-model 綁定)

//父組件
setup(props) {
	const msg = ref("msg");
	const foo = ref('123')
	return{
	foo,msg
	}
}
<!--父組件--!>
{{modelValue}}  {{msg}}
 <HelloWorld v-model:foo="modelValue" v-model:message="msg"></HelloWorld>
 
<!--子組件--!>
  <input type="text" :value="foo" @input="$emit('update:foo', $event.target.value)" />
 <input type="text" :value="message" @input="$emit('update:message', $event.target.value)" />/>
 

在這里插入圖片描述

自定義修飾符的用法,

根據(jù)官方

//父組件
<HelloWorld v-model.capitalize="myText"></HelloWorld>
{{myText}}
setup(){
	return {  myText : ref(22); } //不加ref無法做到響應(yīng)
}
//子組件
//自定義修飾符 capitalize  通過modelModifiers prop 提供給組件 忽視any
 <input type="text" :value="modelValue" @input="emitValue" />
  props: {
    modelValue: String,
    modelModifiers: {
      default: () => ({ capitalize: false })
    }
  },
  created() {
    console.log(this.modelModifiers); // { capitalize: true }
  },
  methods: {
    emitValue(e: any) {
      let value: any = e.target.value;
      if (this.modelModifiers.capitalize) {
        value = value.charAt(0).toUpperCase() + value.slice(1);
      }
      this.$emit("update:modelValue", value);
    }
  }  
//對于帶參數(shù)的 v-model 綁定
 <vModel v-model:foo.capitalize="bar"></vModel>
   props: {
    foo: {
      type: String
    },
    fooModifiers: {
      type: String
    }
  }
  created() {
    console.log(this.fooModifiers); // { capitalize: true }
  }
  <input type="text" :value="foo" @input="$emit('update:foo', $event.target.value)" />

以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • Vue權(quán)限指令控制權(quán)限詳解

    Vue權(quán)限指令控制權(quán)限詳解

    因為項目中需要根據(jù)后端返回的權(quán)限進行功能的顯示隱藏,所以就加了個權(quán)限指令。不用寫if else進行判斷,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)吧
    2022-09-09
  • 八個Vue中常用的v指令詳解

    八個Vue中常用的v指令詳解

    vue常用指令有v-once指令、v-show指令、v-if指令、v-else指令、v-else-if指令、v-for指令、v-html指令、v-text指令、v-bind指令、v-on指令、v-model指令等等,下面這篇文章主要給大家介紹了八個Vue中常用的v指令的相關(guān)資料,需要的朋友可以參考下
    2022-04-04
  • vue-cli創(chuàng)建項目ERROR?in?Conflict:?Multiple?assets?emit?different?content?to?the?same?filename?index.html問題的解決辦法

    vue-cli創(chuàng)建項目ERROR?in?Conflict:?Multiple?assets?emit?dif

    最近vue/cli創(chuàng)建項目后出現(xiàn)了錯誤,下面這篇文章主要給大家介紹了關(guān)于vue-cli創(chuàng)建項目ERROR?in?Conflict:?Multiple?assets?emit?different?content?to?the?same?filename?index.html問題的解決辦法,需要的朋友可以參考下
    2023-02-02
  • Vue中v-for的9種使用案例總結(jié)大全

    Vue中v-for的9種使用案例總結(jié)大全

    v-for是vue的循環(huán)指令,作用是遍歷數(shù)組(對象)的每一個值,這篇文章主要給大家介紹了關(guān)于Vue中v-for的9種使用案例的相關(guān)資料,文中通過代碼介紹的非常詳細,需要的朋友可以參考下
    2023-12-12
  • Vue3.0實現(xiàn)無限級菜單

    Vue3.0實現(xiàn)無限級菜單

    這篇文章主要為大家詳細介紹了基于Vue3.0實現(xiàn)無限級菜單,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-07-07
  • 基于Vue SEO的四種方案(小結(jié))

    基于Vue SEO的四種方案(小結(jié))

    這篇文章主要介紹了基于Vue SEO的四種方案,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-07-07
  • Vue面試題及Vue知識點整理

    Vue面試題及Vue知識點整理

    這篇文章主要介紹了Vue面試題及Vue知識點整理,本文給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友參考下吧
    2018-10-10
  • vue使用this.$message不生效的部分原因及解決方案

    vue使用this.$message不生效的部分原因及解決方案

    這篇文章主要介紹了vue使用this.$message不生效的部分原因及解決方案,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-09-09
  • vue如何通過點擊事件實現(xiàn)頁面跳轉(zhuǎn)詳解

    vue如何通過點擊事件實現(xiàn)頁面跳轉(zhuǎn)詳解

    頁面跳轉(zhuǎn),我們一般都通過路由跳轉(zhuǎn)實現(xiàn),通常情況下可直接使用router-link標(biāo)簽實現(xiàn)頁面跳轉(zhuǎn),下面這篇文章主要給大家介紹了關(guān)于vue如何通過點擊事件實現(xiàn)頁面跳轉(zhuǎn)的相關(guān)資料,需要的朋友可以參考下
    2022-07-07
  • Vue errorHandler異常捕獲

    Vue errorHandler異常捕獲

    這篇文章主要介紹了Vue errorHandler異常捕獲,需要的朋友可以參考下
    2023-10-10

最新評論