Vue3.4中v-model雙向數(shù)據(jù)綁定新玩法詳解
前言
隨著 Vue3.4
版本的發(fā)布,defineModel
也正式轉(zhuǎn)正了。它可以簡(jiǎn)化父子組件之間的雙向綁定
,是目前官方推薦的雙向綁定實(shí)現(xiàn)方式。
之前在 Vue3.3 中,該方法還是實(shí)驗(yàn)性
方法,使用 defineModel 需在 vite.config.ts
里面配置 defineModel
為 true
,配置如下:
export default defineConfig({ plugins: [ vue({ script: { defineModel: true, }, }), ], });
但 Vue3.4
版本中已經(jīng)是穩(wěn)定特性了?。?!
正式介紹 defineModel
defineModel 是一個(gè)新的 <script setup>
宏,旨在簡(jiǎn)化支持 v-model
的組件的實(shí)現(xiàn), 這個(gè)宏用來(lái)聲明一個(gè)雙向綁定 prop
,通過父組件的 v-model
來(lái)使用。
它之前作為實(shí)驗(yàn)性功能在 Vue3.3 中發(fā)布,并在 Vue3.4
中升級(jí)為穩(wěn)定
狀態(tài)?,F(xiàn)在,它還為 v-model修飾符
的使用提供了更好的支持。
defineModel 使用
例舉一個(gè)最簡(jiǎn)單的使用場(chǎng)景: 自定義組件中使用 v-model 來(lái)進(jìn)行數(shù)據(jù)的雙向綁定
<!-- 父組件 --> <template> <div> <!-- 自定義子組件 CustomComponent 使用 v-model 指令綁定 userName --> <CustomComponent v-model="userName" /> </div> </template> <script setup> import { ref } from "vue"; import CustomComponent from "./CustomComponent.vue"; const userName = ref("前端開發(fā)愛好者"); </script>
在 Vue3.3 版本之前,我們通常通過 props
接收 modelValue,然后在更新時(shí),我們會(huì)將更新后的值傳遞給 emit
的 update:modelValue
并執(zhí)行:
<!-- 子組件 CustomComponent --> <template> <input :value="props.modelValue" @input="emit('update:modelValue', $event.target.value)" /> </template> <script setup> import { defineProps, defineEmits } from "vue"; const props = defineProps(["modelValue"]); const emit = defineEmits(["update:modelValue"]); </script>
Vue3.4 版本之后,我們將使用 defineModel
替代子組件中的 props
和 emit
。
<!-- 子組件 CustomComponent --> <template> <input type="text" v-model="modelValue" /> </template> <script setup> const modelValue = defineModel(); </script>
帶參數(shù)/定義多個(gè) v-model
組件中可以支持定義多個(gè) defineModel
,可以滿足綁定多個(gè)雙向綁定的屬性
<!-- 父組件 --> <template> <div> <!-- 自定義子組件 CustomComponent 使用 v-model 指令綁定 userName --> <CustomComponent v-model="userName" v-model:title="title" v-model:subTitle="subTitle" /> </div> </template> <script setup> import { ref } from "vue"; import CustomComponent from "./CustomComponent.vue"; const userName = ref("前端開發(fā)愛好者"); const title = ref("前端開發(fā)愛好者_(dá)title"); const subTitle = ref("前端開發(fā)愛好者_(dá)subTitle"); </script>
<!-- 子組件 CustomComponent --> <template> <input type="text" v-model="modelValue" /> <input type="text" v-model="title" /> <input type="text" v-model="subTitle" /> </template> <script setup> const modelValue = defineModel(); const title = defineModel("title"); const subTitle = defineModel("subTitle"); </script>
修飾符和轉(zhuǎn)換器
為了獲取 v-model
指令使用的修飾符,我們可以像這樣解構(gòu) defineModel() 的返回值:
const [modelValue, modelModifiers] = defineModel() // 對(duì)應(yīng) v-model.trim if (modelModifiers.trim) { // ... }
當(dāng)存在修飾符時(shí),我們可能需要在讀取或?qū)⑵渫交馗附M件時(shí)對(duì)其值進(jìn)行轉(zhuǎn)換。我們可以通過使用 get
和 set
轉(zhuǎn)換器選項(xiàng)來(lái)實(shí)現(xiàn)這一點(diǎn):
const [modelValue, modelModifiers] = defineModel({ // get() 省略了,因?yàn)檫@里不需要它 set(value) { // 如果使用了 .trim 修飾符,則返回裁剪過后的值 if (modelModifiers.trim) { return value.trim() } // 否則,原樣返回 return value } })
參考連接:
結(jié)語(yǔ)
defineModel
的引入標(biāo)志著 Vue
在提升開發(fā)者體驗(yàn)方面邁出了重要的一步?,F(xiàn)在,開發(fā)者可以更加專注于應(yīng)用的邏輯和用戶體驗(yàn),而不是糾結(jié)于數(shù)據(jù)綁定的細(xì)節(jié)。讓我們一起迎接 Vue 3.4 帶來(lái)的更多可能性吧!
以上就是Vue3.4中v-model雙向數(shù)據(jù)綁定新玩法詳解的詳細(xì)內(nèi)容,更多關(guān)于Vue v-model雙向數(shù)據(jù)綁定的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
- vue 2 實(shí)現(xiàn)自定義組件一到多個(gè)v-model雙向數(shù)據(jù)綁定的方法(最新推薦)
- vue3?中v-model語(yǔ)法糖示例詳解
- Vue3?使用v-model實(shí)現(xiàn)父子組件通信的方法(常用在組件封裝規(guī)范中)
- vue3的組件通信&v-model使用實(shí)例詳解
- vue3利用v-model實(shí)現(xiàn)父子組件之間數(shù)據(jù)同步的代碼詳解
- Vue3中v-model語(yǔ)法糖的三種寫法詳解
- vue3+Element?Plus?v-model實(shí)現(xiàn)父子組件數(shù)據(jù)同步的案例代碼
- vue3組件的v-model:value與v-model的區(qū)別解析
相關(guān)文章
Vue動(dòng)態(tài)綁定class、style、background的方式
文章主要介紹了在Vue.js中如何使用動(dòng)態(tài)綁定class、style和background來(lái)實(shí)現(xiàn)動(dòng)態(tài)樣式和背景圖的設(shè)置,通過v-bind指令,可以靈活地根據(jù)數(shù)據(jù)變化來(lái)動(dòng)態(tài)更新元素的樣式和背景2025-01-01深入探討Vue3實(shí)現(xiàn)多數(shù)據(jù)變化監(jiān)聽的方式
隨著 Vue 3 的發(fā)布,框架帶來(lái)了更多的新特性和增強(qiáng),其中之一就是 watch 函數(shù)的升級(jí),這一改進(jìn)使得多個(gè)數(shù)據(jù)的變化偵聽更加優(yōu)雅和靈活,本文將深入探討 Vue 3 中的 watch 函數(shù),以及如何以更加優(yōu)雅的方式實(shí)現(xiàn)對(duì)多個(gè)數(shù)據(jù)變化的監(jiān)聽2023-08-08vue項(xiàng)目打包之后在本地運(yùn)行的實(shí)現(xiàn)方法
這篇文章主要介紹了vue項(xiàng)目打包之后在本地運(yùn)行的實(shí)現(xiàn)方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-07-07M1 pro芯片啟動(dòng)Vue項(xiàng)目的方法步驟
本文主要介紹了M1 pro芯片啟動(dòng)Vue項(xiàng)目的方法步驟,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-11-11vue3?el-table結(jié)合seamless-scroll實(shí)現(xiàn)表格數(shù)據(jù)滾動(dòng)的思路詳解
這篇文章主要介紹了vue3?el-table結(jié)合seamless-scroll實(shí)現(xiàn)表格數(shù)據(jù)滾動(dòng),創(chuàng)建兩個(gè)table,隱藏第一個(gè)table的body部分,這樣就能得到一個(gè)固定的head,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-07-07vue如何實(shí)現(xiàn)跨頁(yè)面?zhèn)鬟f與接收數(shù)組并賦值
這篇文章主要介紹了vue如何實(shí)現(xiàn)跨頁(yè)面?zhèn)鬟f與接收數(shù)組并賦值,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-04-04解決vue動(dòng)態(tài)下拉菜單 有數(shù)據(jù)未反應(yīng)的問題
這篇文章主要介紹了解決vue動(dòng)態(tài)下拉菜單 有數(shù)據(jù)未反應(yīng)的問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來(lái)看看吧2020-08-08