0

0

Vue中如何实现父子组件之间的通信?

穿越時空

穿越時空

发布时间:2025-07-29 10:53:01

|

1002人浏览过

|

来源于php中文网

原创

vue 中,父子组件通信有四种常见方式。1. 父传子:通过 props 传递数据,子组件声明接收的属性,父组件绑定动态值;2. 子传父:使用 $emit 触发自定义事件,父组件监听并处理;3. 双向绑定:通过 v-model 实现,本质是 props 和 $emit 的语法糖,也可用 .sync 修饰符自定义;4. 方法调用:利用 ref 让父组件直接访问子组件的方法或数据。每种方式都有其适用场景,合理使用可提升代码清晰度与可维护性。

Vue中如何实现父子组件之间的通信?

在 Vue 中,父子组件通信是开发中最基础也是最常用的功能之一。实现方式简单直接,但理解清楚每种方式的适用场景能让你写出更清晰、可维护的代码。

1. 父传子:通过 props

父组件向子组件传递数据,最常见的方式就是使用 props。你可以把 props 想象成子组件对外声明的“接收口”,父组件通过这个接口传值进去。

比如你有一个子组件 ChildComponent,它需要接收一个名字:

立即学习前端免费学习笔记(深入)”;

<!-- ChildComponent.vue -->
<template>
  <div>你好,{{ name }}</div>
</template>

<script>
export default {
  props: ['name']
}
</script>

父组件这样使用它:

<!-- ParentComponent.vue -->
<child-component :name="parentName" />

这里用的是动态绑定(:name),这样父组件中的 parentName 数据一变,子组件也会同步更新。

注意点:

  • props 是单向数据流,不建议在子组件中直接修改 props 的值。
  • 可以给 props 设置类型校验和默认值,提高健壮性。

2. 子传父:通过自定义事件

子组件想通知父组件做点什么,通常是用 $emit 触发一个自定义事件,然后父组件监听这个事件。

比如你想让子组件点击按钮后告诉父组件一个信息:

<!-- ChildComponent.vue -->
<template>
  <button @click="notifyParent">点我</button>
</template>

<script>
export default {
  methods: {
    notifyParent() {
      this.$emit('message', '我是子组件的消息')
    }
  }
}
</script>

父组件监听这个事件:

Android服务Service_详解 WORD版
Android服务Service_详解 WORD版

本文档主要讲述的是Android服务Service_详解;服务(Service)是Android系统中4个应用程序组件之一(其他的组件详见3.2节的内容)。服务主要用于两个目的:后台运行和跨进程访问。通过启动一个服务,可以在不显示界面的前提下在后台运行指定的任务,这样可以不影响用户做其他事情。通过AIDL服务可以实现不同进程之间的通信,这也是服务的重要用途之一。希望本文档会给有需要的朋友带来帮助;感兴趣的朋友可以过来看看

下载
<!-- ParentComponent.vue -->
<child-component @message="handleMessage" />

<script>
export default {
  methods: {
    handleMessage(msg) {
      console.log('收到消息:', msg)
    }
  }
}
</script>

这种方式非常适合处理用户交互后的反馈,比如表单提交、选项变更等。

3. 使用 v-model 实现双向绑定(其实是语法糖)

Vue 提供了 v-model 来简化父子组件之间的双向绑定,其实它底层还是基于 props$emit

比如你在子组件里定义了一个 value 的 prop,并在改变时触发 input 事件:

<!-- ChildComponent.vue -->
<input :value="value" @input="$emit('input', $event.target.value)" />

父组件就可以这样使用:

<child-component v-model="parentData" />

这等价于:

<child-component :value="parentData" @input="parentData = $event" />

如果你不想用 valueinput 这两个默认名,还可以用 .sync 修饰符或者自定义 model。

4. 父子组件方法调用(ref)

有时候你需要父组件直接调用子组件的方法,或者访问子组件的数据,可以用 ref

比如你在子组件里写个方法:

<!-- ChildComponent.vue -->
<script>
export default {
  methods: {
    sayHello() {
      console.log('Hello from child')
    }
  }
}
</script>

父组件拿到这个 ref 后可以调用:

<child-component ref="childRef" />

<script>
export default {
  mounted() {
    this.$refs.childRef.sayHello()
  }
}
</script>

这种方式适合做一些初始化操作或主动触发子组件行为,但要小心别滥用,否则容易破坏组件封装性


基本上就这些。父子通信看似简单,但在实际项目中合理选择方式,能让组件之间协作更顺畅,也更容易调试和维护。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
硬盘接口类型介绍
硬盘接口类型介绍

硬盘接口类型有IDE、SATA、SCSI、Fibre Channel、USB、eSATA、mSATA、PCIe等等。详细介绍:1、IDE接口是一种并行接口,主要用于连接硬盘和光驱等设备,它主要有两种类型:ATA和ATAPI,IDE接口已经逐渐被SATA接口;2、SATA接口是一种串行接口,相较于IDE接口,它具有更高的传输速度、更低的功耗和更小的体积;3、SCSI接口等等。

1825

2023.10.19

PHP接口编写教程
PHP接口编写教程

本专题整合了PHP接口编写教程,阅读专题下面的文章了解更多详细内容。

594

2025.10.17

php8.4实现接口限流的教程
php8.4实现接口限流的教程

PHP8.4本身不内置限流功能,需借助Redis(令牌桶)或Swoole(漏桶)实现;文件锁因I/O瓶颈、无跨机共享、秒级精度等缺陷不适用高并发场景。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

2350

2025.12.29

java接口相关教程
java接口相关教程

本专题整合了java接口相关内容,阅读专题下面的文章了解更多详细内容。

45

2026.01.19

点击input框没有光标怎么办
点击input框没有光标怎么办

点击input框没有光标的解决办法:1、确认输入框焦点;2、清除浏览器缓存;3、更新浏览器;4、使用JavaScript;5、检查硬件设备;6、检查输入框属性;7、调试JavaScript代码;8、检查页面其他元素;9、考虑浏览器兼容性。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

196

2023.11.24

JavaScript浏览器渲染机制与前端性能优化实践
JavaScript浏览器渲染机制与前端性能优化实践

本专题围绕 JavaScript 在浏览器中的执行与渲染机制展开,系统讲解 DOM 构建、CSSOM 解析、重排与重绘原理,以及关键渲染路径优化方法。内容涵盖事件循环机制、异步任务调度、资源加载优化、代码拆分与懒加载等性能优化策略。通过真实前端项目案例,帮助开发者理解浏览器底层工作原理,并掌握提升网页加载速度与交互体验的实用技巧。

3

2026.03.06

Rust内存安全机制与所有权模型深度实践
Rust内存安全机制与所有权模型深度实践

本专题围绕 Rust 语言核心特性展开,深入讲解所有权机制、借用规则、生命周期管理以及智能指针等关键概念。通过系统级开发案例,分析内存安全保障原理与零成本抽象优势,并结合并发场景讲解 Send 与 Sync 特性实现机制。帮助开发者真正理解 Rust 的设计哲学,掌握在高性能与安全性并重场景中的工程实践能力。

21

2026.03.05

PHP高性能API设计与Laravel服务架构实践
PHP高性能API设计与Laravel服务架构实践

本专题围绕 PHP 在现代 Web 后端开发中的高性能实践展开,重点讲解基于 Laravel 框架构建可扩展 API 服务的核心方法。内容涵盖路由与中间件机制、服务容器与依赖注入、接口版本管理、缓存策略设计以及队列异步处理方案。同时结合高并发场景,深入分析性能瓶颈定位与优化思路,帮助开发者构建稳定、高效、易维护的 PHP 后端服务体系。

108

2026.03.04

AI安装教程大全
AI安装教程大全

2026最全AI工具安装教程专题:包含各版本AI绘图、AI视频、智能办公软件的本地化部署手册。全篇零基础友好,附带最新模型下载地址、一键安装脚本及常见报错修复方案。每日更新,收藏这一篇就够了,让AI安装不再报错!

51

2026.03.04

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Git 教程
Git 教程

共21课时 | 4万人学习

Django 教程
Django 教程

共28课时 | 4.8万人学习

React 教程
React 教程

共58课时 | 5.8万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号