Vue3 defineModel 原理解析

1. 引言

在上一篇文章中探討了v-model的實現原理🔗。本文將聚焦于Vue3.4版本新增的defineModel語法糖,它顯著簡化了組件中v-model的實現方式。我們將詳細解析defineModel的工作原理,并與3.4版本之前實現組件v-model的方法進行對比。

2. Vue3.4 之前的 v-model 實現

在 Vue3.4 之前,要在組件中實現 v-model,我們需要:

  1. 通過 props 接收父組件傳遞的值
  2. 通過 emit 事件向父組件發送更新

示例代碼:

<!-- 子組件 CustomInput.vue -->
<template><input:value="modelValue"@input="$emit('update:modelValue', $event.target.value)"/>
</template><script setup>
defineProps(['modelValue'])
defineEmits(['update:modelValue'])
</script><!-- 父組件使用 -->
<template><CustomInput v-model="text" />
</template>

這種方式需要我們手動定義 props 和 emits,并且在每次值更新時都需要觸發 emit 事件。

3. defineModel 的使用方式

Vue3.4 引入的 defineModel 大大簡化了這個過程:

<!-- 子組件 CustomInput.vue -->
<template><input v-model="model" />
</template><script setup>
const model = defineModel()
</script><!-- 父組件使用方式保持不變 -->
<template><CustomInput v-model="text" />
</template>

4. defineModel 工作原理

defineModel 本質上是一個編譯時的語法糖,它會在編譯階段被轉換為 props 和 emits 的組合。讓我們看看它的工作原理:

  1. 編譯時轉換
    當我們使用 defineModel() 時,編譯器會將其轉換為:
const props = defineProps({modelValue: {required: true}
})const emit = defineEmits(['update:modelValue'])const model = computed({get() {return props.modelValue},set(value) {emit('update:modelValue', value)}
})
  1. 自動處理修飾符
    defineModel 還可以處理各種修飾符:
<script setup>
// 支持修飾符
const model = defineModel({default: '',type: String,required: true
})
</script>

5. defineModel 的高級用法

5.1 多個 v-model 綁定

<!-- 子組件 -->
<script setup>
const firstName = defineModel('firstName')
const lastName = defineModel('lastName')
</script><!-- 父組件 -->
<template><UserProfilev-model:firstName="first"v-model:lastName="last"/>
</template>

5.2 使用修飾符

<script setup>
const model = defineModel({set(value) {// 在設置值之前進行轉換return value.trim()}
})
</script>

6. defineModel 的優勢

  1. 代碼簡潔:顯著減少了模板代碼的數量
  2. 更直觀:使用方式更接近原生表單元素的 v-model
  3. 類型支持:提供了更好的 TypeScript 類型推導
  4. 維護性:減少了出錯的可能性,使代碼更容易維護

7. 總結

defineModel 是 Vue3.4 中一個重要的改進,它通過巧妙的語法糖設計,簡化了組件 v-model 的實現方式。它不僅讓代碼更加簡潔、直觀,還提供了更好的類型支持。理解其工作原理對于我們更好地使用這個特性非常重要。在新的項目中,建議優先考慮使用 defineModel 來實現組件的雙向綁定。

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/diannao/87256.shtml
繁體地址,請注明出處:http://hk.pswp.cn/diannao/87256.shtml
英文地址,請注明出處:http://en.pswp.cn/diannao/87256.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

GRPO訓練布局感知的強化學習多模態文檔解析框架-Infinity-Parser

前期《文檔智能》專欄詳細中介紹了文檔智能解析詳細pipline鏈路技術方案&#xff0c;如下圖&#xff1a; 現在來看一個新思路&#xff0c;指出pipline鏈路依賴大量標注數據、并且會出現錯誤傳播問題&#xff0c;導致解析效果不佳&#xff0c;故提出一個基于布局強化學習&…

【超詳細】訊飛智能車PC電腦燒錄指南(高級系統部署與恢復)

本指南旨在詳細指導您如何使用PC電腦上的瑞芯微開發工具&#xff0c;對訊飛智能車進行固件燒錄、分區鏡像燒寫和設備擦除等高級操作。這些操作通常用于系統出現嚴重問題、需要全新部署固件或進行底層恢復時。 一、所需設備與工具 在開始操作之前&#xff0c;請確保您準備好以…

【親測可用】html+css3+ajax+php文件夾拖放上傳系統(保持文件結構上傳)

文件夾拖放上傳系統&#xff08;保持文件結構&#xff09; 下面是一個完整的HTML5CSS3AJAXPHP實現&#xff0c;支持拖放文件夾上傳并保持原有文件結構的解決方案。 前端部分 (index.html) <!DOCTYPE html> <html lang"zh-CN"> <head><meta c…

什么是數據清洗?數據清洗有哪些步驟?

目錄 一、數據清洗的定義和重要性 1. 數據清洗的定義 2. 數據清洗的重要性 二、數據清洗的前期準備 1. 明確清洗目標 2. 了解數據來源和背景 3. 制定清洗計劃 三、數據清洗的具體步驟 1. 數據審計 2. 處理缺失值 3. 處理重復值 4. 處理異常值 5. 數據標準化 6. 數…

Vue3+TypeScript中v-bind()的原理與用法

在 Vue 3 的單文件組件&#xff08;SFC&#xff09;中&#xff0c;v-bind() 用于在 <style> 塊中動態綁定 CSS 值到組件的響應式數據&#xff0c;實現了狀態驅動樣式的能力。下面詳細講解其原理和用法&#xff1a; 一、核心原理 CSS 變量注入 Vue 編譯器會將 v-bind() 轉…

2 geotools入門示例

1. 設置 Spring Boot 項目并集成 GeoTools 依賴 首先&#xff0c;你需要創建一個新的 Spring Boot 項目。你可以使用 Spring Initializr 來快速生成項目骨架。 選擇以下依賴&#xff1a; Web: Spring Web (用于創建 REST API)Developer Tools: Spring Boot DevTools (可選&a…

深度解析String不可變性:從Java底層到設計哲學

一、String不可變性的直觀理解 在Java中,String對象一旦創建,其內容就不可更改。任何看似"修改"String的操作,實際上都是創建了一個全新的String對象。這種設計是Java語言基礎架構的重要部分,理解其底層原理對編寫高效、安全的Java程序至關重要。 String str =…

C++并發編程-2.C++ 線程管控

參考&#xff1a;https://llfc.club/category?catid225RaiVNI8pFDD5L4m807g7ZwmF#!aid/2Tuk4RfvfBC788LlqnQrWiPiEGW 1. 簡歷 本節介紹C線程管控&#xff0c;包括移交線程的歸屬權&#xff0c;線程并發數量控制以及獲取線程id等基本操作。 2. 線程歸屬權 比如下面&#xff…

Qt面試常問

1.QT信號與槽的底層原理&#xff1f; 底層通過元對象系統和事件循環完成的&#xff0c;能夠在運行期間動態處理信號槽之間的連接與斷開&#xff0c;而不是像函數調用那樣在編譯期間就完全確定了。元對象系統包含&#xff1a;QObject類、Q_OBJECT宏定義、moc編譯器當發送一個信…

【git】錯誤

【成功解決】開代理 unable to access ‘https://github.com/laigeoffer/pmhub.git/’: Recv failure: Connection was reset

什么是狀態機?狀態機入門

狀態機&#xff1a;優雅管理復雜邏輯的Python實踐 在軟件開發中&#xff0c;狀態機&#xff08;Finite State Machine, FSM&#xff09; 是管理多狀態轉換的利器。它將行為分解為離散的狀態、事件和轉移規則&#xff0c;大幅提升代碼的可讀性與可維護性。本文通過Python示例解析…

【Python打卡Day41】簡單CNN@浙大疏錦行

可以看到即使在深度神經網絡情況下&#xff0c;準確率仍舊較差&#xff0c;這是因為特征沒有被有效提取----真正重要的是特征的提取和加工過程。MLP把所有的像素全部展平了&#xff08;這是全局的信息&#xff09;&#xff0c;無法布置到局部的信息&#xff0c;所以引入了卷積神…

MySQL中InnoDB存儲引擎底層原理與MySQL日志機制深入解析

MySQL的內部組件結構如下&#xff1a; 大體來說&#xff0c;MySQL 可以分為 Server 層和存儲引擎層兩部分。 Server層 主要包括連接器、查詢緩存、分析器、優化器、執行器等&#xff0c;涵蓋 MySQL 的大多數核心服務功能&#xff0c;以及所有的內置函數&#xff08;如日期、…

MCP基本概念

基本概念 現在大模型交互的熱門形式&#xff1a; 第一、Agent與Tools(工具)的交互Agent需要調用外部工具和APl、訪問數據庫、執行代碼等。> MCP 第二、Agent與Agent(其他智能體或用戶)的交互Agent需要理解其他Agent的意圖、協同完成任務、與用戶進行自然的對話。 > A2A…

Docker容器相關命令介紹和示例

Docker 容器是鏡像的運行實例。以下是常用的 Docker 容器命令及其示例&#xff1a; 1. 運行容器 docker run [選項] <鏡像名> [命令]常用選項&#xff1a; -d&#xff1a;后臺運行&#xff08;守護模式&#xff09;-it&#xff1a;交互式終端--name&#xff1a;指定容…

【Akshare】高效下載股票和ETF數據

在量化投資與金融數據分析的世界里&#xff0c;獲取高質量的市場數據是構建有效策略的關鍵。Python庫Akshare為我們提供了一個強大且易于使用的接口&#xff0c;可以輕松地從網絡上抓取各類金融數據。本文將詳細介紹如何利用Akshare下載股票和ETF的歷史行情數據。 安裝Akshare…

分布式--3--分布式事務

1 簡介 事務在單系統中的表現&#xff1a;多次數據庫操作用事務進行管理&#xff0c;來保證ACID原則。 但是如果各個模塊都是單獨獨立出來的微服務&#xff0c;進行了分布式部署&#xff0c;單系統里的事務將不能保證各個數據庫操作的一致性&#xff0c;因此就需要分布式事務來…

不同建模方式的介紹 RTL建模筆記(1)

說明&#xff1a;該專欄"RTL建模筆記"是《RTL Modeling with SystemVerilog for Simulation and Synthesis》的翻譯&#xff1b;該筆記略過了第一章第一小節中背景介紹內容&#xff0c;以及第二小節前面部分的門級、RTL級建模介紹&#xff0c;對于后續學習不影響。 …

<13>-MySQL用戶管理

目錄 一&#xff0c;用戶管理操作 1&#xff0c;創建用戶 2&#xff0c;查詢用戶 3&#xff0c;修改密碼 4&#xff0c;刪除用戶 二&#xff0c;數據庫權限 1&#xff0c;用戶授權 2&#xff0c;回收權限 一&#xff0c;用戶管理操作 1&#xff0c;創建用戶 --創建用戶…

如何使用超低噪聲電源提高AD 時鐘電路質量,改善超聲系統的圖像質量

超聲波技術是醫療診斷和其他應用中廣泛使用的無創工具&#xff0c;已經從靜態圖像進化到動態圖像&#xff0c;從黑白呈現變為彩色多普勒圖像。這些重大進步主要是由于引入了數字超聲技術。雖然這些進步提高了超聲成像的有效性和通用性&#xff0c;但同樣重要的是&#xff0c;這…