组件通信-(父子组件通信)

news/2024/11/16 20:52:12/

目录

一、什么是组件通信

二、组件关系的分类

三、组件通信解决方案

四、父传子

五、子传父


一、什么是组件通信

组件通信,就是指组件与组件之间的数据传递。组件的数据是独立的,无法直接访问其他组件的数据。如果想使用其他组件的数据,就需要进行组件通信。

不同的组件关系对应的组件通信方案应该是不一样的。

二、组件关系的分类

  1. 父子关系
  2. 非父子关系

如下图:

三、组件通信解决方案

父子通信流程图:

四、父传子

父组件通过props将数据传递给子组件。

父组件直接包裹了子组件Son。现在的需求是:父组件有一个数据myTitle,子组件需要对该数据进行展示,默认情况下不能直接使用,需要通过props的方式将数据传递给子组件。

props就是给组件标签新增的一个个自定义属性。比如div标签的title属性、img标签的src属性。如下图:

其实组件标签上也可以加一些属性,在加这些属性的时候,就是在为当前组件添加数据,也就是在给当前组件传值。而子组件内部通过props接收,然后子组件就可以使用该数据了。

代码分析

在<Son :title="myTitle"></Son>这段代码中,为什么要使用:title?因为:title其实是v-bind:title的简写,它的作用是为标签设置动态的属性,title的属性值是通过该组件的data()函数的myTitle属性得到的,而在实际的开发中,myTitle属性的值其实是会动态变化,如果直接使用title=".....",则title的属性值是写死了的;如果使用:title=".....",省略部分是可以填写data()函数里面的属性名的,所以data()函数里面的属性如果发生变化,则title属性也会动态变化。

<Son :title="myTitle"></Son>这一步已经成功为子组件传递了数据。然后子组件内部可以通过props来进行接收。如图:

[ ]是数组的意思,代表可以接收多个传值,而里面写的属性名需要与父组件传值时的属性名保持一致。如<Son :title="myTitle"></Son>,父组件传值时使用的属性名为title,则子组件通过props:['title']来得到父组件传递的数据。

子组件使用从父组件传递的值:

五、子传父

子组件利用$emit通知父组件,进行修改更新。

子组件中准备一个按钮<button @click="handleClick">修改title</button>,点击按钮后,触发handleClick点击事件,在该事件中,再通过$emit触发事件,给父组件发送消息通知,一旦发送了消息通知,父组件需要对子组件所发送的消息进行监听,比如子组件:this.$emit('changeTitle','传智教育'),第一个参数changeTitle就是$emit触发的事件名,则父组件需要对changeTitle事件进行监听,即:<Son :title="myTitle" @changeTitle=''changeFn"></Son>,监听的目的就是收到子组件传递过来的消息,并且可以提供对应的处理函数changeFn,在该处理函数的形参中就可以拿到从子组件传递过来的消息,如下图:

这里面的newTitle就是子组件传递过来的消息:"传智教育"。然后就可以使用newTitle来更新myTitle的数据了。


http://www.ppmy.cn/news/1456071.html

相关文章

鸿蒙内核源码分析(事件控制篇) | 任务间多对多的同步方案

官方概述 先看官方对事件的描述. 事件&#xff08;Event&#xff09;是一种任务间通信的机制&#xff0c;可用于任务间的同步。 多任务环境下&#xff0c;任务之间往往需要同步操作&#xff0c;一个等待即是一个同步。事件可以提供一对多、多对多的同步操作。 一对多同步模型…

#04 构建您的第一个神经网络:PyTorch入门指南

文章目录 前言理论基础神经网络层的组成前向传播与反向传播 神经网络设计步骤1&#xff1a;准备数据集步骤2&#xff1a;构建模型步骤3&#xff1a;定义损失函数和优化器步骤4&#xff1a;训练模型步骤5&#xff1a;评估模型结论 前言 在过去的几天里&#xff0c;我们深入了解了…

2024年第七届可再生能源与环境工程国际会议(REEE 2024)即将召开!

2024年第七届可再生能源与环境工程国际会议&#xff08;REEE 2024&#xff09;将于2024 年8月28-30日在法国南特举行。共绘绿色未来&#xff0c;全球同频共振&#xff01;REEE 2024将汇聚全球可再生能源与环境工程领域的专家学者和业界精英&#xff0c;共同探讨行业发展的前沿技…

笔试强训Day15 二分 图论

平方数 题目链接&#xff1a;平方数 (nowcoder.com) 思路&#xff1a;水题直接过。 AC code&#xff1a; #include<iostream> #include<cmath> using namespace std; int main() {long long int n; cin >> n;long long int a sqrtl(n);long long int b …

Linux内核--设备驱动(六)媒体驱动框架整理(2)--视频

目录 一、引言 二、V4L2 ------>2.1、主要结构体 ------------>2.2.1、video_device ------------>2.2.2、v4l2_device ------------>2.2.3、v4l2_subdev ------>2.2、流程 ------>2.3、驱动实例 ------>2.4、V4L2的ioctl类型 ------------>…

百度语音识别开发笔记

目录 简述 开发环境 1、按照官方文档步骤开通短语音识别-普通话 2、创建应用 3、下载SDK 4、SDK集成 5、相关接口简单说明 5.1权限和key 5.2初始化 5.3注册回调消息 5.4开始转换 5.5停止转换 6、问题 简述 最近想做一些语音识别的应用&#xff0c;对比了几个大厂…

C++:多继承虚继承

在C中&#xff0c;虚继承&#xff08;Virtual Inheritance&#xff09;是一种特殊的继承方式&#xff0c;用于解决菱形继承&#xff08;Diamond Inheritance&#xff09;问题。菱形继承指的是一个类同时继承自两个或更多个具有共同基类的类&#xff0c;从而导致了多个实例同一个…

NodeJS 如何在npm运行时设置Windows控制台的标题?

通过代码设置 const server app.listen(port, () > {console.log(主机名称&#xff1a;, global.hostname)console.log(主机IP地址&#xff1a;, global.host)console.log(后台服务端口号&#xff1a;, port)console.log(恭喜你&#xff0c;启动成功!)process.title node …