当前位置: 首页 > news >正文

前端流行框架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.xdnf.cn/news/457579.html

相关文章:

  • 阿里云ECS部署Dify
  • go依赖查询工具之godepgraph(分析main.go的依赖树)
  • 机器学习08-损失函数
  • 【上位机——WPF】Window标签常用属性
  • 概率相关问题
  • win10电脑无法访问局域网内其他共享电脑文件的问题
  • 用C语言实现了——一个基于顺序表的插入排序演示系统
  • Java并发编程:锁机制
  • 数据库--处理模型(Processing Model)(二)
  • AWS CloudHSM:金融级密钥安全管理实战,如何通过FIPS 140-2认证守护数据生命线?
  • aws 实践创建policy + Role
  • 黑马程序员c++2024版笔记 第一章
  • Delphi 中 BPL(2):大型项目中 BPL 对性能的影响及调优策略
  • 2025年11月软考各科目难度及适合人群分析
  • 浪潮云边协同:赋能云计算变革的强力引擎
  • YOLO11改进-模块-引入空间增强前馈网络SEFN 提高多尺度 遮挡
  • 华宇TAS应用中间件与亿信华辰多款软件产品完成兼容互认证
  • 2025 OceanBase 开发者大会全议程指南
  • 【AI论文】用于评估和改进大型语言模型中指令跟踪的多维约束框架
  • 如何卸载并重新安装 Mozilla Firefox 浏览器
  • 2025年,多模态特征融合只会更火
  • 基于Rust语言的Rocket框架和Sqlx库开发WebAPi项目记录(一)
  • WPS文字的“邮件合并”功能-----批量生成word文档
  • 一文讲透 Vue3 + Three.js 材质属性之皮革篇【扫盲篇】
  • 【hadoop】sqoop案例 hive->mysql
  • 2.ch452a 4线驱动按键扫描
  • Spring MVC 拦截器 (HandlerInterceptor) 是什么? 它与 Servlet Filter 有什么区别?
  • Kotlin并发请求的一些知识记录
  • Go 语言中接口类型转换为具体类型
  • 修复Windows 10中由于SearchProtocolHost.exe而导致的CPU使用率过高