Vue3 新特性defineModel用法如何讓 v-model 寫法更優(yōu)雅
一、前言
在 Vue3.3 版本中,官方新增了一個非常實用的語法糖 —— defineModel。它的主要作用是讓我們在組件中更方便地使用 v-model,簡化了以往繁瑣的寫法。
如果你之前寫過 Vue2 或 Vue3 的組件,應(yīng)該對 props + emit 結(jié)合 v-model 的寫法很熟悉。但這種寫法相對麻煩,而 defineModel 正是為了解決這個問題而生的。
二、回顧傳統(tǒng)v-model用法
在 Vue3 中,父子組件傳遞雙向綁定一般是這樣寫的:
子組件(傳統(tǒng)寫法)
<script setup>
import { defineProps, defineEmits } from 'vue'
const props = defineProps({
modelValue: String
})
const emit = defineEmits(['update:modelValue'])
function onInput(e) {
emit('update:modelValue', e.target.value)
}
</script>
<template>
<input :value="props.modelValue" @input="onInput" />
</template>父組件
<script setup>
import ChildInput from './ChildInput.vue'
import { ref } from 'vue'
const text = ref('')
</script>
<template>
<ChildInput v-model="text" />
<p>父組件里的值:{{ text }}</p>
</template>可以看到:
- 子組件需要寫
props和emit,再手動觸發(fā)update:modelValue。 - 寫起來比較繁瑣,不夠直觀。
三、defineModel的出現(xiàn)
Vue3.3 引入的 defineModel 大大簡化了這個流程。它讓子組件可以直接聲明一個 響應(yīng)式變量,這個變量就自動和 v-model 綁定。
子組件(使用defineModel)
<script setup> const modelValue = defineModel() </script> <template> <input v-model="modelValue" /> </template>
是不是簡單很多?
- 不再需要
defineProps、defineEmits。 - 直接用一個變量就能完成父子雙向綁定。
四、defineModel的進階用法
1. 指定類型
<script setup lang="ts"> const modelValue = defineModel<string>() </script>
這樣在 TS 下會有更好的類型提示。
2. 自定義prop名稱
默認情況下,defineModel() 對應(yīng)的就是 v-model(即 modelValue)。
但如果你想用多個 v-model,也可以給它起名字:
<script setup>
const title = defineModel('title')
const content = defineModel('content')
</script>
<template>
<input v-model="title" placeholder="標題"/>
<textarea v-model="content" placeholder="內(nèi)容"></textarea>
</template>父組件這樣用:
<ArticleEditor v-model:title="postTitle" v-model:content="postContent" />
3. 添加默認值和校驗規(guī)則
defineModel 也支持和 defineProps 類似的配置:
<script setup>
const modelValue = defineModel({
type: String,
default: 'Hello Vue3',
required: true
})
</script>
這樣可以確保綁定的值有默認值,也能做一些簡單的類型校驗。
五、defineModel的優(yōu)缺點
優(yōu)點
- 極簡寫法 —— 不用再寫
props+emit。 - 語義清晰 —— 一眼就能看出這是
v-model綁定的值。 - 支持多
v-model—— 寫起來比原生的props + emit更直觀。
缺點
- 只在 Vue3.3+ 可用,老版本不支持。
- 對于復(fù)雜的業(yè)務(wù)邏輯,可能還是需要
props+emit來處理更靈活的場景。
六、適用場景
- 表單類組件(輸入框、選擇器、彈窗開關(guān)等)。
- 需要多個
v-model的復(fù)雜組件(如富文本編輯器:v-model:value、v-model:config)。 - 需要簡化組件寫法的場景。
七、總結(jié)
defineModel 是 Vue3.3 之后提供的一個語法糖,它讓我們在子組件中使用 v-model 更加簡潔高效:
- 不需要再寫
props和emit。 - 可以直接定義一個響應(yīng)式變量和父組件雙向綁定。
- 支持類型、默認值、多
v-model。
如果你項目的 Vue 版本在 3.3 以上,強烈推薦用起來!
到此這篇關(guān)于Vue3 新特性defineModel用法如何讓 v-model 寫法更優(yōu)雅的文章就介紹到這了,更多相關(guān)vue defineModel 內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
element?ui富文本編輯器的使用效果與步驟(quill-editor)
富文本編輯器在任何項目中都會用到,在Element中我們推薦vue-quill-editor組件,下面這篇文章主要給大家介紹了關(guān)于element?ui富文本編輯器的使用效果與步驟(quill-editor)的相關(guān)資料,需要的朋友可以參考下2022-10-10
Vue的transition-group與Virtual Dom Diff算法的使用
這篇文章主要介紹了Vue的transition-group與Virtual Dom Diff算法的使用,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-12-12
Vue3實現(xiàn)clipboard復(fù)制的使用示例
在日常開發(fā)中,為用戶提供復(fù)制文本功能的需求比較常見,下面介紹一款vue3可用的插件,可以快速實現(xiàn)這個功能,感興趣的可以了解一下2023-11-11
解決vue3.0運行項目warning Insert `·` prettier/pret
這篇文章主要介紹了解決vue3.0運行項目warning Insert `·` prettier/prettier問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2023-10-10
解決vue 使用setTimeout,離開當(dāng)前路由setTimeout未銷毀的問題
這篇文章主要介紹了解決vue 使用setTimeout,離開當(dāng)前路由setTimeout未銷毀的問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-07-07
vue如何通過點擊事件實現(xiàn)頁面跳轉(zhuǎn)詳解
頁面跳轉(zhuǎn),我們一般都通過路由跳轉(zhuǎn)實現(xiàn),通常情況下可直接使用router-link標簽實現(xiàn)頁面跳轉(zhuǎn),下面這篇文章主要給大家介紹了關(guān)于vue如何通過點擊事件實現(xiàn)頁面跳轉(zhuǎn)的相關(guān)資料,需要的朋友可以參考下2022-07-07
vue 內(nèi)置過濾器的使用總結(jié)(附加自定義過濾器)
這篇文章主要介紹了vue 內(nèi)置過濾器的使用總結(jié)(附加自定義過濾器),詳細的介紹了各種過濾器的使用,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-12-12

