Vue组件通信$attrs、$listeners实现原理解析


Posted in Javascript onSeptember 03, 2020

前言

vue通信手段有很多种,props/emit、vuex、event bus、provide/inject 等。还有一种通信方式,那就是$attrs和$listeners,之前早就听说这两个api,趁着有空来补补。这种方式挺优雅,使用起来也不赖。下面例子都会通过父、子、孙子,三者的关系来说明使用方式。

Vue组件通信$attrs、$listeners实现原理解析

$attrs

官方解释:

包含了父作用域中不作为 prop 被识别 (且获取) 的特性绑定 (class和style除外)。当一个组件没有声明任何 prop 时,这里会包含所有父作用域的绑定 (class和style除外),并且可以通过v-bind="$attrs"传入内部组件——在创建高级别的组件时非常有用。

我的理解:

接收除了props声明外的所有绑定属性(class、style除外)

图解:

Vue组件通信$attrs、$listeners实现原理解析

由于child.vue 在 props 中声明了 name 属性,$attrs 中只有age、gender两个属性,输出结果为:

{age: "20",gender: "man"}

Vue组件通信$attrs、$listeners实现原理解析

另外可以在 grandson.vue 上通过 v-bind="$attrs", 可以将属性继续向下传递,让 grandson.vue 也能访问到父组件的属性,这在传递多个属性时会显得很便捷,而不用一条条的进行绑定。

如果想要添加其他属性,可继续绑定属性。但要注意的是,继续绑定的属性和 $attrs 中的属性有重复时,继续绑定的属性优先级会更高。

$listeners

官方解释:

包含了父作用域中的 (不含.native修饰器的)v-on事件监听器。它可以通过v-on="$listeners"传入内部组件——在创建更高层次的组件时非常有用。

我的理解:

接收除了带有.native事件修饰符的所有事件监听器

图解:

Vue组件通信$attrs、$listeners实现原理解析

parent.vue中对 child.vue 绑定了两个事件,带有.native的 click 事件和一个自定义事件,所以在 child.vue 中,输出$listeners的结果为:

{ customEvent: fn }

Vue组件通信$attrs、$listeners实现原理解析

同 attrs 属性一样,可以通过 v-on="$listeners",将事件监听器继续向下传递,让 grandson.vue 访问到事件,且可以使用 $emit 触发 parent.vue 的函数。

如果想要添加其他事件监听器,可继续绑定事件。但要注意的是,继续绑定的事件和 $listeners 中的事件有重复时,不会被覆盖。当 grandson.vue 触发 customEvent 时,child.vue 和 parent.vue 的事件都会被触发,触发顺序类似于冒泡,先到 child.vue 再到 parent.vue。

使用场景:

组件传值时使用: 爷爷在父亲组件传递值,父亲组件会通过$attrs获取到不在父亲props里面的所有属性,父亲组件通过在孙子组件上绑定$attrs 和 $listeners 使孙组件获取爷爷传递的值并且可以调用在爷爷那里定义的方法;

对一些UI库进行二次封装时使用:比如element-ui,里面的组件不能满足自己的使用场景的时候,会二次封装,但是又想保留他自己的属性和方法,那么这个时候时候$attrs和$listners是个完美的解决方案。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
JQuery.ajax传递中文参数的解决方法 推荐
Mar 28 Javascript
JavaScript日期时间格式化函数分享
May 05 Javascript
jquery模拟alert的弹窗插件
Jul 31 Javascript
AngularJS基础 ng-keypress 指令简单示例
Aug 02 Javascript
JS中数组重排序方法
Nov 11 Javascript
bootstrap的常用组件和栅格式布局详解
May 02 Javascript
node.js连接MongoDB数据库的2种方法教程
May 17 Javascript
Bootstrap下拉菜单更改为悬停(hover)触发的方法
May 24 Javascript
修改npm全局安装模式的路径方法
May 15 Javascript
详解JavaScript 中 if / if...else...替换方式
Jul 15 Javascript
JS实现的简单tab切换功能完整示例
Jun 20 Javascript
JS实现网页时钟特效
Mar 25 Javascript
Vue父组件监听子组件生命周期
Sep 03 #Javascript
JavaScript 几种循环方式以及模块化的总结
Sep 03 #Javascript
Vuejs通过拖动改变元素宽度实现自适应
Sep 02 #Javascript
Vue Object.defineProperty及ProxyVue实现双向数据绑定
Sep 02 #Javascript
Vue 组件的挂载与父子组件的传值实例
Sep 02 #Javascript
vue中的.$mount('#app')手动挂载操作
Sep 02 #Javascript
vue中提示$index is not defined错误的解决方式
Sep 02 #Javascript
You might like
php Xdebug 调试扩展的安装与使用.
2010/03/13 PHP
PHP面试题之文件目录操作
2015/10/15 PHP
php获取当前月与上个月月初及月末时间戳的方法
2016/12/05 PHP
Prototype ObjectRange对象学习
2009/07/19 Javascript
动感效果的TAB选项卡jquery 插件
2011/07/09 Javascript
jquery使用jquery.zclip插件复制对象的实例教程
2013/12/04 Javascript
同域jQuery(跨)iframe操作DOM(实例讲解)
2013/12/19 Javascript
javascript获取浏览器类型和版本的方法(js获取浏览器版本)
2014/03/13 Javascript
利用JavaScript的AngularJS库制作电子名片的方法
2015/06/18 Javascript
JS随机洗牌算法之数组随机排序
2016/03/23 Javascript
node.js中使用Export和Import的方法
2017/09/18 Javascript
基于jquery trigger函数无法触发a标签的两种解决方法
2018/01/06 jQuery
使用vue-cli脚手架工具搭建vue-webpack项目
2019/01/14 Javascript
JS浅拷贝和深拷贝原理与实现方法分析
2019/02/28 Javascript
javascript设计模式 ? 桥接模式原理与应用实例分析
2020/04/13 Javascript
二种python发送邮件实例讲解(python发邮件附件可以使用email模块实现)
2013/12/03 Python
Python实现二分查找与bisect模块详解
2017/01/13 Python
Python编程实现微信企业号文本消息推送功能示例
2017/08/21 Python
django rest framework之请求与响应(详解)
2017/11/06 Python
Python 找到列表中满足某些条件的元素方法
2018/06/26 Python
flask框架使用orm连接数据库的方法示例
2018/07/16 Python
python实现字符串和字典的转换
2018/09/29 Python
关于不懂Chromedriver如何配置环境变量问题解决方法
2019/06/12 Python
利用 Flask 动态展示 Pyecharts 图表数据方法小结
2019/09/04 Python
使用Python代码实现Linux中的ls遍历目录命令的实例代码
2019/09/07 Python
如何在python中实现随机选择
2019/11/02 Python
Python 实现使用空值进行赋值 None
2020/03/12 Python
python画图时设置分辨率和画布大小的实现(plt.figure())
2021/01/08 Python
人力资源专业推荐信
2013/11/29 职场文书
销售主管的自我评价分享
2014/01/03 职场文书
企业新年寄语
2014/04/04 职场文书
北京申奥口号
2014/06/19 职场文书
护理学院专科毕业生求职信
2014/06/28 职场文书
2014新生大学四年计划书
2014/09/21 职场文书
国庆65周年演讲稿:回首往昔,展望未来
2014/09/21 职场文书
python+opencv实现目标跟踪过程
2022/06/21 Python