前端流行框架Vue3教程:16. 組件事件配合`v-model`使用

組件事件配合v-model使用

如果是用戶輸入,我們希望在獲取數據的同時發送數據配合v-model 來使用,幫助理解組件間的通信和數據綁定。


🧩 第一步:創建子組件(SearchComponent.vue)

這個組件用于處理用戶的搜索輸入,并將輸入值傳遞給父組件。

? 功能說明:
  1. 數據屬性 search:在 [data()]中定義了一個名為 search 的數據屬性,作為輸入框的雙向綁定。
  2. 使用 v-model:模板中的 <input type="text" v-model="search"> 實現了用戶輸入與 search 數據的同步。
  3. 監聽器 [watch]:當 search 發生變化時,通過 $emit 觸發一個名為 searchEvent 的自定義事件,并傳入新的值。
  4. 輸出事件 searchEvent:該事件允許父組件訂閱并接收子組件的數據更新。
📁 代碼結構:
<script>
export default {data() {return {search: ''}},watch: {search(newVal) {this.$emit('searchEvent', newVal)}}
}
</script><template>搜索:<input type="text" v-model="search">
</template>

🌐 第二步:創建主組件(Main.vue)

這個組件負責顯示來自子組件的數據,并展示到頁面上。

? 功能說明:
  1. 引入子組件:使用 import SearchComponent from './SearchComponent.vue' 引入子組件。
  2. 注冊組件:在 [components]屬性中注冊 SearchComponent
  3. 數據屬性 search:用來保存從子組件接收到的搜索內容。
  4. 方法 getSearch(data):響應子組件發出的 searchEvent 事件,將數據賦值給 this.search
  5. 模板渲染:使用插值表達式 {{ search }} 顯示當前搜索內容,并通過 @searchEvent="getSearch" 監聽子組件的事件。
📁 代碼結構:
<script>
import SearchComponent from './SearchComponent.vue'export default {components: {SearchComponent},data() {return {search: ''}},methods: {getSearch(data) {this.search = data}}
}
</script><template><h3>Main</h3><p>搜索內容 {{ search }}</p><SearchComponent @searchEvent="getSearch"/>
</template>

🔄 第三步:運行項目

確保你的項目結構如下:

src/
├── components/
│   ├── SearchComponent.vue
│   └── Main.vue
├── App.vue
└── main.js
🔧 修改 [App.vue]:
<template><Main />
</template><script>
import Main from './components/Main.vue'export default {components: {Main}
}
</script>

然后啟動項目:

npm run dev

訪問 http://localhost:端口,你應該能看到一個搜索框和下方顯示的搜索內容。

在這里插入圖片描述


🧠 總結

  • 父子組件通信:通過 $emit 在子組件中發送事件,在父組件中監聽并處理。
  • 數據綁定v-model 簡化了表單元素與數據之間的雙向綁定。
  • 模塊化開發:將功能拆分為多個組件,提高可維護性和復用性。

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

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

相關文章

《Navicat之外的新選擇:實測支持國產數據庫的SQLynx核心功能解析》

數據庫工具生態的新變量 在數據庫管理工具領域&#xff0c;Navicat長期占據開發者心智。但隨著國產數據庫崛起和技術信創需求&#xff0c;開發者對工具的兼容性、輕量化和本土化適配提出了更高要求。近期體驗了一款名為SQLynx的國產數據庫管理工具&#xff08;麥聰旗下產品&am…

AgenticSeek開源的完全本地的 Manus AI。無需 API,享受一個自主代理,它可以思考、瀏覽 Web 和編碼,只需支付電費。

?一、軟件介紹 文末提供程序和源碼下載 AgenticSeek開源的完全本地的 Manus AI。無需 API&#xff0c;享受一個自主代理&#xff0c;它可以思考、瀏覽 Web 和編碼&#xff0c;只需支付電費。這款支持語音的 AI 助手是 Manus AI 的 100% 本地替代品 &#xff0c;可自主瀏覽網頁…

vue3.0的name屬性插件——vite-plugin-vue-setup-extend

安裝 這個由于是在開發環境下的一個插件 幫助我們支持name屬性 所以需要是-D npm i vite-plugin-vue-setup-extend -D在pasckjson中無法注釋每個插件的用處 可以在vscode中下載一個JsonComments這樣可以在json中添加注釋方便日后維護和查閱API 引入 在vite.config.js中 im…

Linux基礎 -- 在內存中使用chroot修復eMMC

Linux基礎 – 在內存中使用chroot修復eMMC 概述 本教程將介紹如何在Linux系統中&#xff0c;使用chroot在內存中構建一個臨時系統&#xff0c;并在不依賴原有系統的情況下修復eMMC&#xff08;如/dev/mmcblk2&#xff09;磁盤。該方法適用于嵌入式系統修復、磁盤清理以及離線…

人工智能、深度學習、機器學習的聯系與區別

定義 人工智能&#xff08;AI - Artificial Intelligence&#xff09; &#xff1a;是研究、開發用于模擬、延伸和擴展人的智能的理論、方法、技術及應用系統的一門新的技術科學。它旨在讓計算機能夠像人類一樣思考、學習和決策&#xff0c;涉及到諸如計算機視覺、自然語言處理…

web第二次課后作業--設計一個注冊登錄系統

一、頁面展示 登錄頁面 提交頁面 二、代碼 2.1 登錄頁面 <% page language"java" contentType"text/html; charsetUTF-8"pageEncoding"UTF-8"%><html> <head><meta http-equiv"Content-Type" content"…

電腦桌面便簽哪個好?2025年電腦免費用的便簽軟件推薦

我們都知道&#xff0c;一個優秀的桌面便簽軟件可以成為提高效率的得力助手。無論是記錄臨時靈感、管理待辦事項&#xff0c;還是提醒重要日程&#xff0c;合適的便簽工具都能讓您的數字生活更加有序。本文將為您介紹2025年最值得推薦的免費電腦桌面便簽軟件&#xff0c;從Wind…

【SPIN】用Promela驗證順序程序:從斷言到SPIN實戰(SPIN學習系列--2)

你寫了一段自認為“天衣無縫”的程序&#xff0c;但如何確保它真的沒有bug&#xff1f;靠手動測試&#xff1f;可能漏掉邊界情況&#xff1b;靠直覺&#xff1f;更不靠譜&#xff01;這時候&#xff0c;Promela SPIN組合就像程序的“顯微鏡”——用形式化驗證技術&#xff0c;…

LabVIEW中樣條插值實現及應用

在 LabVIEW 編程環境下&#xff0c;B - 樣條插值是處理數據擬合與曲線平滑的重要工具。它憑借靈活的特性和良好的數學性質&#xff0c;在眾多工程領域中發揮著關鍵作用&#xff0c;能夠高效地根據離散數據點生成平滑連續的曲線&#xff0c;為數據分析和處理提供了有力支持。 一…

【油藏地球物理正演軟件ColchisFM】基于數據驅動的油藏參數疊前地震反演研究進展

科吉思基于油藏地球物理參數的正演軟件ColchisFM&#xff0c;有機融合了巖石物理正演與地震正演&#xff0c;具有良好的適用性和便捷性&#xff0c;在業內已經廣泛使用。當用戶在做正演模擬的同時&#xff0c;自然會聯想到是否可以直接開展油藏地球物理參數反演呢&#xff1f;答…

互聯網大廠Java求職面試:AI與大模型集成的云原生架構設計

互聯網大廠Java求職面試&#xff1a;AI與大模型集成的云原生架構設計 引言 在現代互聯網企業中&#xff0c;AI與大模型技術的應用已經成為不可或缺的一部分。特別是在短視頻平臺、電商平臺和金融科技等領域&#xff0c;如何高效地將大模型集成到現有的云原生架構中是一個巨大…

Web GIS可視化地圖框架Leaflet、OpenLayers、Mapbox、Cesium、ArcGis for JavaScript

Mapbox、OpenLayers、Leaflet、ArcGIS for JavaScript和Cesium是五種常用的Web GIS地圖框架&#xff0c;它們各有優缺點&#xff0c;適用于不同的場景。還有常見的3d庫和高德地圖、百度地圖。 1. Mapbox 官網Mapbox Gl JS案列&#xff1a;https://docs.mapbox.com/mapbox-gl-…

專項智能練習(加強題型)-DA-02

2. 單選題 近年來&#xff0c;“斜杠青年”成為很多人的時尚追求。它指的是一群不再滿足“專一職業”生活方式&#xff0c;而選擇擁有多重職業和身份的多元生活人群。對此&#xff0c;有人認為&#xff0c;新產業新技術新業態不斷更迭&#xff0c;激烈的競爭促使青年人不斷進行…

使用gitbook 工具編寫接口文檔或博客

步驟一&#xff1a;在項目目錄中初始化一個 GitBook 項目 mkdir mybook && cd mybook git init npm init -y步驟二&#xff1a;添加書籍結構&#xff08;如 book.json, README.md&#xff09; echo "# 我的書" > README.md echo "{}" > bo…

Malformed input or input contains unmappable characters解決

JDK 17 文件上傳編碼異常解決方案技術文檔 1. 問題背景 在 JDK 17 環境下&#xff0c;文件上傳過程中可能拋出 Malformed input or input contains unmappable characters 錯誤。此問題通常由以下原因觸發&#xff1a; 文件路徑/名稱包含非 ASCII 字符&#xff08;如中文、日…

MyBatis 的分頁插件 c

前言 大型項目的數據體量很大&#xff0c;在前端界面展示時為保障展示效果&#xff0c;會要求接口快速返回&#xff0c;這時候后端會選擇分頁獲取數據&#xff0c;只傳遞要查詢的頁碼數據。這就避免了大多問題&#xff0c;達到快速返回的效果。 常用的分頁有2種&#xff1a; …

Linux:理解文件系統

1.理解硬件 1.1磁盤 機械磁盤是計算機中的?個機械設備 磁盤--- 外設 慢 容量?&#xff0c;價格便宜 1.2磁盤物理結構 1.3磁盤的存儲結構 扇區&#xff1a;是磁盤存儲數據的基本單位&#xff0c;512字節&#xff0c;塊設備 如何定位?個扇區呢&#xff1f; 確定磁頭要訪…

用 openssl 測試 tls 連接

以 baidu 為例&#xff0c;命令行為&#xff1a; openssl s_client -tlsextdebug -connect baidu.com:443 得到的輸出為&#xff1a; CONNECTED(00000003) TLS server extension "renegotiation info" (id65281), len1 0000 - 00 …

今日行情明日機會——20250515

上證指數縮量收陰線&#xff0c;個股跌多漲少&#xff0c;上漲波段4月9日以來已有24個交易日&#xff0c;時間周期上處于上漲末端&#xff0c;注意風險。 深證指數縮量收陰線&#xff0c;日線上漲結束的概率在增大&#xff0c;注意風險。 2025年5月15日漲停股主要行業方向分…

Axure RP9:列表新增

文章目錄 列表新增思路新增按鈕操作說明保存新增交互設置列表新增 思路 利用中繼器新增行實現列表新增功能 新增按鈕操作說明 工具欄中添加新增圖標及標簽,在圖標標簽基礎上添加熱區;對熱區添加鼠標單擊時交互事件,同步插入如下動作:顯示/隱藏動作,設置目標元件為新增窗…