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

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

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

前言

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

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

export default defineConfig({
  plugins: [
    vue({
      script: {
        defineModel: true,
      },
    }),
  ],
});

Vue3.4 版本中已經(jīng)是穩(wěn)定特性了!?。?/p>

正式介紹 defineModel

defineModel 是一個新的 <script setup> 宏,旨在簡化支持 v-model 的組件的實現(xiàn), 這個宏用來聲明一個雙向綁定 prop,通過父組件的 v-model 來使用。

它之前作為實驗性功能在 Vue3.3 中發(fā)布,并在 Vue3.4 中升級為穩(wěn)定狀態(tài)?,F(xiàn)在,它還為 v-model修飾符的使用提供了更好的支持。

defineModel 使用

例舉一個最簡單的使用場景: 自定義組件中使用 v-model 來進(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,然后在更新時,我們會將更新后的值傳遞給 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ù)/定義多個 v-model

組件中可以支持定義多個 defineModel,可以滿足綁定多個雙向綁定的屬性

<!-- 父組件 -->
<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()

// 對應(yīng) v-model.trim
if (modelModifiers.trim) {
  // ...
}

當(dāng)存在修飾符時,我們可能需要在讀取或?qū)⑵渫交馗附M件時對其值進(jìn)行轉(zhuǎn)換。我們可以通過使用 getset 轉(zhuǎn)換器選項來實現(xiàn)這一點:

const [modelValue, modelModifiers] = defineModel({
  // get() 省略了,因為這里不需要它
  set(value) {
    // 如果使用了 .trim 修飾符,則返回裁剪過后的值
    if (modelModifiers.trim) {
      return value.trim()
    }
    // 否則,原樣返回
    return value
  }
})

參考連接:

結(jié)語

defineModel 的引入標(biāo)志著 Vue 在提升開發(fā)者體驗方面邁出了重要的一步?,F(xiàn)在,開發(fā)者可以更加專注于應(yīng)用的邏輯和用戶體驗,而不是糾結(jié)于數(shù)據(jù)綁定的細(xì)節(jié)。讓我們一起迎接 Vue 3.4 帶來的更多可能性吧!

以上就是Vue3.4中v-model雙向數(shù)據(jù)綁定新玩法詳解的詳細(xì)內(nèi)容,更多關(guān)于Vue v-model雙向數(shù)據(jù)綁定的資料請關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

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

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

    文章主要介紹了在Vue.js中如何使用動態(tài)綁定class、style和background來實現(xiàn)動態(tài)樣式和背景圖的設(shè)置,通過v-bind指令,可以靈活地根據(jù)數(shù)據(jù)變化來動態(tài)更新元素的樣式和背景
    2025-01-01
  • 深入探討Vue3實現(xiàn)多數(shù)據(jù)變化監(jiān)聽的方式

    深入探討Vue3實現(xiàn)多數(shù)據(jù)變化監(jiān)聽的方式

    隨著 Vue 3 的發(fā)布,框架帶來了更多的新特性和增強(qiáng),其中之一就是 watch 函數(shù)的升級,這一改進(jìn)使得多個數(shù)據(jù)的變化偵聽更加優(yōu)雅和靈活,本文將深入探討 Vue 3 中的 watch 函數(shù),以及如何以更加優(yōu)雅的方式實現(xiàn)對多個數(shù)據(jù)變化的監(jiān)聽
    2023-08-08
  • Vue前后端不同端口的實現(xiàn)方法

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

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

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

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

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

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

    M1 pro芯片啟動Vue項目的方法步驟

    本文主要介紹了M1 pro芯片啟動Vue項目的方法步驟,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-11-11
  • vue3?el-table結(jié)合seamless-scroll實現(xiàn)表格數(shù)據(jù)滾動的思路詳解

    vue3?el-table結(jié)合seamless-scroll實現(xiàn)表格數(shù)據(jù)滾動的思路詳解

    這篇文章主要介紹了vue3?el-table結(jié)合seamless-scroll實現(xiàn)表格數(shù)據(jù)滾動,創(chuàng)建兩個table,隱藏第一個table的body部分,這樣就能得到一個固定的head,本文通過實例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-07-07
  • vue如何實現(xiàn)跨頁面?zhèn)鬟f與接收數(shù)組并賦值

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

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

    基于vue的驗證碼組件的示例代碼

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

    解決vue動態(tài)下拉菜單 有數(shù)據(jù)未反應(yīng)的問題

    這篇文章主要介紹了解決vue動態(tài)下拉菜單 有數(shù)據(jù)未反應(yīng)的問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-08-08

最新評論