亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Vue3.4中v-model雙向數(shù)據(jù)綁定新玩法詳解

 更新時(shí)間:2024年03月22日 10:03:22   作者:前端開發(fā)愛好者  
defineModel?是一個(gè)新的?<script?setup>?宏,旨在簡(jiǎn)化支持?v-model?的組件的實(shí)現(xiàn),?這個(gè)宏用來(lái)聲明一個(gè)雙向綁定?prop,下面我們就來(lái)看看他的具體使用吧

前言

隨著 Vue3.4 版本的發(fā)布,defineModel 也正式轉(zhuǎn)正了。它可以簡(jiǎn)化父子組件之間的雙向綁定,是目前官方推薦的雙向綁定實(shí)現(xiàn)方式。

之前在 Vue3.3 中,該方法還是實(shí)驗(yàn)性方法,使用 defineModel 需在 vite.config.ts 里面配置 defineModeltrue,配置如下:

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ì)將更新后的值傳遞給 emitupdate: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 替代子組件中的 propsemit

<!-- 子組件 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)換。我們可以通過使用 getset 轉(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)文章!

相關(guān)文章

  • Vue動(dòng)態(tài)綁定class、style、background的方式

    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)聽的方式

    深入探討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-08
  • Vue前后端不同端口的實(shí)現(xiàn)方法

    Vue前后端不同端口的實(shí)現(xiàn)方法

    今天小編就為大家分享一篇Vue前后端不同端口的實(shí)現(xiàn)方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來(lái)看看吧
    2018-09-09
  • vue項(xiàng)目打包之后在本地運(yùn)行的實(shí)現(xiàn)方法

    vue項(xiàng)目打包之后在本地運(yùn)行的實(shí)現(xiàn)方法

    這篇文章主要介紹了vue項(xiàng)目打包之后在本地運(yùn)行的實(shí)現(xiàn)方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-07-07
  • Vue如何指定不編譯的文件夾和favicon.ico

    Vue如何指定不編譯的文件夾和favicon.ico

    這篇文章主要介紹了Vue如何指定不編譯的文件夾和favicon.ico,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-04-04
  • M1 pro芯片啟動(dòng)Vue項(xiàng)目的方法步驟

    M1 pro芯片啟動(dòng)Vue項(xiàng)目的方法步驟

    本文主要介紹了M1 pro芯片啟動(dòng)Vue項(xiàng)目的方法步驟,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-11-11
  • vue3?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)的思路詳解

    這篇文章主要介紹了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-07
  • vue如何實(shí)現(xiàn)跨頁(yè)面?zhèn)鬟f與接收數(shù)組并賦值

    vue如何實(shí)現(xiàn)跨頁(yè)面?zhèn)鬟f與接收數(shù)組并賦值

    這篇文章主要介紹了vue如何實(shí)現(xiàn)跨頁(yè)面?zhèn)鬟f與接收數(shù)組并賦值,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-04-04
  • 基于vue的驗(yàn)證碼組件的示例代碼

    基于vue的驗(yàn)證碼組件的示例代碼

    這篇文章主要介紹了基于vue的驗(yàn)證碼組件的示例代碼,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來(lái)看看吧
    2019-01-01
  • 解決vue動(dòng)態(tài)下拉菜單 有數(shù)據(jù)未反應(yīng)的問題

    解決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

最新評(píng)論