关于|关于 vue2.x 的 $attrs 和 $listeners
$attrs
$attrs 用于多层次组件传递参数(组件标签的attribute,class和style除外),爷爷辈组件向孙子辈组件传递参数(注:参数不能被父辈prop识别,一旦被父辈prop识别且获取,则孙子辈组件不能获取到该参数)
【关于|关于 vue2.x 的 $attrs 和 $listeners】写法如下:(注:v-bind不能用简写 :
)
下面举个栗子:
爷爷(GrandFather)向父亲(Father)传递一个
msg1
向孙子(GrandSon)传递一个
msg2
,孙子会一并接收 msg1
(然而被父亲接走了,所以孙子收不到 msg1
)
GrandFather:
Father: {{ msg1 }}
GrandSon: {{ msg1 }}{{ msg2 }}
界面现实结果:
GrandFather:
Father: msg1
GrandSon: msg2
$listeners $listeners 用于多层次组件传递事件监听器,爷爷辈组件向父辈、孙子辈、曾孙子辈……组件传递事件(与 $attrs 不同,不存在半路被拦截的情况)
写法如下:(注:v-on 不能用简写
@
,虽然不报错,但是也不生效)
下面继续使用 爷爷-> 父亲 -> 孙子 的栗子:
爷爷(GrandFather)给父亲(Father)绑定一个
click
事件父亲通过点击 div 触发
click
事件,同时向孙子(GrandSon)传递 $listeners
GrandFather:
Father: {{ msg1 }}
GrandSon: {{ msg1 }}{{ msg2 }}
界面:
GrandFather:
Father: msg1
GrandSon: msg2
点击
Father: msg1
,控制台显示:father click
trriger click
点击
GrandSon: msg2
,控制台显示:grandson click
trriger click
推荐阅读
- Python 获取字典中的第一个键
- 网络编程(优雅的关闭)
- 17个实用的JavaScript数组和对象的方法
- 数据迁移方案汇总
- 【JS30-Wes Bos】异步操作实现的小字典
- Spring|Spring Boot 整合定时任务,可以动态编辑的定时任务!
- java分布式面试降级组件Hystrix的功能特性
- Mysql优化经典案例
- mysql案例_10个最经典的 MySQL 数据库运维案例
- 大数据和云(在云中实施大数据的详情分析)