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

Vue3子組件實現(xiàn)v-model用法的示例代碼

 更新時間:2024年04月25日 09:27:50   作者:方周率  
在Vue 3中,實現(xiàn)自定義的input組件并支持v-model綁定,涉及到對modelValue這個默認(rèn)prop的處理和對應(yīng)的update:modelValue事件的觸發(fā),本文給大家介紹了Vue3子組件實現(xiàn)v-model用法的示例,需要的朋友可以參考下

前言

在Vue 3中,實現(xiàn)自定義的input組件并支持v-model綁定,涉及到對modelValue這個默認(rèn)prop的處理和對應(yīng)的update:modelValue事件的觸發(fā)。Vue 3使得這個過程比Vue 2更為簡化和靈活,尤其是在可以自定義綁定的屬性和事件名方面。

步驟 1: 創(chuàng)建自定義Input組件

首先,創(chuàng)建一個自定義的Input組件,該組件接收一個modelValue prop,并在用戶輸入時觸發(fā)一個update:modelValue事件。這是v-model的標(biāo)準(zhǔn)實現(xiàn)方式。

<!-- CustomInput.vue -->
<template>
  <input
    :value="modelValue"
    @input="onInput"
  >
</template>

<script setup>
import { defineProps, defineEmits } from 'vue';

// 定義接受的props
const props = defineProps({
  modelValue: String
});

// 定義可能觸發(fā)的事件
const emit = defineEmits(['update:modelValue']);

// 輸入事件處理函數(shù)
function onInput(event) {
  // 觸發(fā)事件,并傳遞新的值
  emit('update:modelValue', event.target.value);
}
</script>

在這個組件中,我們使用defineProps來聲明組件期望接收的prop(modelValue),并用defineEmits聲明組件會觸發(fā)的事件(update:modelValue)。當(dāng)input元素的值發(fā)生變化時(用戶輸入時),我們觸發(fā)update:modelValue事件,將新的輸入值作為事件的參數(shù)傳遞出去。

步驟 2: 在父組件中使用自定義Input組件

然后,在父組件中使用這個自定義Input組件,并通過v-model進行數(shù)據(jù)綁定。

<!-- ParentComponent.vue -->
<template>
  <div>
    <CustomInput v-model="textInput" />
  </div>
</template>

<script setup>
import { ref } from 'vue';
import CustomInput from './CustomInput.vue';

const textInput = ref('');
</script>

在這個父組件中,textInput是一個響應(yīng)式引用,存儲用戶在自定義輸入框中輸入的數(shù)據(jù)。通過v-model指令,Vue 自動處理modelValue prop的傳入和update:modelValue事件的監(jiān)聽。

自定義model參數(shù)

如果你需要自定義v-model綁定的屬性名和事件名(例如,如果你希望屬性名不是modelValue,或者你希望事件名不是update:modelValue),你可以在組件上指定v-model的參數(shù)。

自定義屬性和事件名的CustomInput組件

<!-- CustomInput.vue -->
<template>
  <input
    :value="customValue"
    @input="onInput"
  >
</template>

<script setup>
import { defineProps, defineEmits } from 'vue';

const props = defineProps({
  customValue: String
});
const emit = defineEmits(['customUpdate']);

function onInput(event) {
  emit('customUpdate', event.target.value);
}
</script>

在父組件中使用

<!-- ParentComponent.vue -->
<template>
  <div>
    <CustomInput v-model:customValue="textInput" />
  </div>
</template>

在這種情況下,:customValue告訴Vue使用customValue作為prop并監(jiān)聽customUpdate事件來更新textInput。

通過這種方式,你可以在Vue 3中靈活地實現(xiàn)自定義的input組件,允許通過標(biāo)準(zhǔn)或自定義的方式使用v-model進行數(shù)據(jù)雙向綁定。這大大增加了組件的通用性和可重用性。

以上就是Vue3子組件實現(xiàn)v-model用法的示例代碼的詳細(xì)內(nèi)容,更多關(guān)于Vue3子組件實現(xiàn)v-model的資料請關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • 詳解Vue中的Props與Data細(xì)微差別

    詳解Vue中的Props與Data細(xì)微差別

    這篇文章主要介紹了詳解Vue中的Props與Data細(xì)微差別,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-03-03
  • vue3+ts+vite使用el-table表格渲染記錄重復(fù)情況

    vue3+ts+vite使用el-table表格渲染記錄重復(fù)情況

    這篇文章主要給大家介紹了關(guān)于vue3+ts+vite使用el-table表格渲染記錄重復(fù)情況的相關(guān)資料,我們可以通過合并渲染、數(shù)據(jù)緩存或虛擬化等技術(shù)來減少重復(fù)渲染的次數(shù),文中通過代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2023-12-12
  • VUE2實現(xiàn)事件驅(qū)動彈窗示例

    VUE2實現(xiàn)事件驅(qū)動彈窗示例

    本篇文章主要介紹了VUE2實現(xiàn)事件驅(qū)動彈窗示例,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-10-10
  • vue 粒子特效的示例代碼

    vue 粒子特效的示例代碼

    本篇文章主要介紹了vue 粒子特效的示例代碼,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-09-09
  • Vue頁面中播放音頻文件的方法詳解

    Vue頁面中播放音頻文件的方法詳解

    這篇文章主要為大家詳細(xì)介紹了Vue實現(xiàn)頁面中播放音頻文件的相關(guān)方法,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下
    2025-02-02
  • vue實現(xiàn)滾動條始終懸浮在頁面最下方

    vue實現(xiàn)滾動條始終懸浮在頁面最下方

    這篇文章主要為大家詳細(xì)介紹了vue實現(xiàn)滾動條始終懸浮在頁面最下方,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-04-04
  • vue組件系列之TagsInput詳解

    vue組件系列之TagsInput詳解

    TagsInput 是一種可編輯的輸入框,通過回車或者分號來分割每個標(biāo)簽,用回退鍵刪除上一個標(biāo)簽。這篇文章主要介紹了vue組件TagsInput的相關(guān)知識,需要的朋友可以參考下
    2020-05-05
  • Element布局組件el-row和el-col的使用

    Element布局組件el-row和el-col的使用

    這篇文章主要介紹了Element布局組件el-row和el-col的使用方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-08-08
  • Vuex中的getter和mutation的區(qū)別詳解

    Vuex中的getter和mutation的區(qū)別詳解

    在現(xiàn)代前端開發(fā)中,狀態(tài)管理是一個不可忽視的話題,而Vuex作為Vue.js的官方狀態(tài)管理庫,在大型應(yīng)用中扮演著至關(guān)重要的角色,當(dāng)我們使用Vuex進行狀態(tài)管理時,getter和mutation是兩個重要的概念,在本文中,我們將詳細(xì)探討getter和mutation的區(qū)別,需要的朋友可以參考下
    2024-12-12
  • vue?v-model的詳細(xì)講解(推薦!)

    vue?v-model的詳細(xì)講解(推薦!)

    vue中經(jīng)常使用到和這類表單元素,vue對于這些元素的數(shù)據(jù)綁定和我們以前經(jīng)常用的jQuery有些區(qū)別,下面這篇文章主要給大家介紹了關(guān)于vue?v-model的相關(guān)資料,需要的朋友可以參考下
    2022-04-04

最新評論