vue组件深层次传值方式-$attrs/$listeners

Vue组件A到C的深层通信通常通过B组件中转,但当嵌套过多时,$attrs和$listeners在Vue2.4中引入以简化通信。$attrs包含未声明为prop的父属性(除class和style),而$listeners则包含父组件的v-on事件监听器。两者在子组件中结合使用,能有效传递属性和事件,减少代码复杂性。
摘要由CSDN通过智能技术生成

a t t r s 与 attrs与 attrslisteners的主要应用是实现多层嵌套传递。
在这里插入图片描述
组件A与组件B通信一般都会使用组件B中转,即A传递给B,B再给C,但是如果A到C组件之间嵌套的组件过多,需要传递的事件和属性较多,会导致代码繁琐,代码维护困难。在vue2.4中,为了解决该需求,引入了 a t t r s 和 attrs和 attrslisteners,新增了inheritAttrs选项。

$attrs的使用

官方定义:
包含了父作用域中不作为prop 被识别 (且获取) 的特性绑定 (class和 style除外)。当一个组件没有声明任何 prop 时,这里会包含所有父作用域的绑定 (class和 style除外),并且可以通过 v-bind="$attrs" 传入内部组件——在创建高级别的组件时非常有用。
(好抽象一脸懵逼。。。)
a t t r s 只 代 表 的 是 那 些 没 有 被 声 明 为 p r o p s 的 属 性 , 如 果 某 个 p r o p 被 子 组 件 中 声 明 了 ( 就 是 这 个 属 性 已 经 在 子 组 件 的 p r o p s 中 了 ) , 在 子 组 件 中 的 attrs只代表的是那些没有被声明为props的属性,如果某个prop被子组件中声明了(就是这个属性已经在子组件的props中了),在子组件中的 attrspropsprop

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值