父子组件之间通信的方式
- 父子组件之间如何进行通信呢?
- 父组件传递给子组件:通过props属性
- 子组件传递给父组件:通过$emit触发事件
父组件传递给子组件
- 在开发中很常见的就是父子组件之间通信,比如父组件有一些数据,需要子组件来进行展示;
- 这个时候我们可以通过props来完成组件之间的通信
- 什么是Props呢
- Props是你可以在组件上注册一些自定义的attribute;
- 父组件给这些attribute赋值,子组件通过attribute的名称获取到对应的值;
- Props有两种常见的用法:
- 方式一:字符串数组,数组中的字符串就是attribute的名称;
- 方式二:对象类型,对象类型我们可以在指定attribute名称的同时,指定它需要传递的类型,是否是必需、默认值等等

Props的对象用法
非Prop的Attribute
- 什么是非Prop的Attribute呢
- 当我们传递给一个组件某个属性,但是该属性并没有定义对应的props或者emits时,就称之为非Prop的Attribute
- 常见的包括class、style、id属性等
- Attribute继承
- 当组件有单个根节点时,非Prop的Attribute将自动添加到根节点的Attribute中
禁用Attribute继承和多根节点
- 如果我们不希望组件的根元素继承attribute,可以在组件中设置inhritAttrs:false
- 禁用attribute继承的
常见情况
是需要将attribute应用于根元素之外的其他元素
;
- 我们可以通过
$attrs来访问所有的 非props的attribute
<div>
我是NotPropAttribue组件
<h2 :class="$attrs.class"></h2>
</div>
- 多个根节点的attribute
- 多个根节点的attribute如果没有显示的绑定,那么会报警告,我们必须手动的指定要绑定到哪一个属性上:
<template>
<div :class="$attr.class">我是NotPropAttribute组件1</div>
<div>我是NotPropAttribute组件2</div>
<div>我是NotPropAttribute组件3</div>
</tempalte>
子组件传递给父组件
- 什么情况下子组件需要传递内容到父组件呢?
- 当子组件有一些事情发生的时候,比如在组件中发生了点击,父组件需要切换内容
- 子组件有一些内容想要传递给父组件的时候
- 我们如何完成上面的操作
- 首先,我们需要在子组件中定义好在某些情况下触发的事件名称
- 其次,在父组件中以v-on的方式传入要监听的事件名称,并且绑定到对应的方法中
- 最后,在子组件中发生某个事件的时候,根据事件名称触发对应的事件;