Vue 父子组件数据传递的四种方式( inheritAttrs + $attrs + $listeners)


Posted in Javascript onMay 04, 2018

当我们在书写 vue 组件的时候,也许可能会用到数据传递;将父组件的数据传递给子组件,有时候也需要通过子组件去事件去触发父组件的事件;

每当我们遇到这样的需求的时候,我们总是会想到有三种解决办法:

通过 props 的方式向子组件传递(父子组件)

vuex 进行状态管理(父子组件和非父子组件) vuex

非父子组件的通信传递 Vue Event Bus ,使用Vue的实例,实现事件的监听和发布,实现组件之间的传递。

后来再逛社区的时候我又发现了还有第四种传递方式, inheritAttrs + $attrs + $listeners

附上原文链接Vue2.4版本中新添加的 attrs 以及 listeners 属性使用 和 Vue.js最佳实践(五招让你成为Vue.js大师)

基本是大部分的公司或者项目都是用前面两种,我司也不例外;好像曾经在官方文档看到过, vuex 适合用在大型的项目中。第三种方式我曾在我的毕设中用到过,其他地方我好像目前是没有看到,当时只有一个功能需要在兄弟组件之间传递数据,用 vuex 的话,大材小用,另外还需要时间成本。所以我选择了 Vue Event Bus ;最后一种方式的话,我目前还没有看到过在项目的应用。但是我个人觉得既然有这个 api 那肯定是有他存在的道理。不然它存在还有何意义的??如果有需求我个人觉得可以尝试用一用;拥抱变化,拥抱机会

工作之后发现,碰到 bug 有时候常规的方式,并不一定是最好的。跳出常规思维,跳出常规方式去解决问题,可能会更加好。常规方法能够解决问题但是未免有些臃肿。在实践的采坑中体会更有意思

inheritAttrs + $attrs + $listeners

inheritAttrs :默认是 true

我的解释就是:没有被子组件继承的父组件属性,不会当做特性展示在子组件根元素上面。说起来,听起来好像有些拗口,看截图看代码你就明白了

inheritAttrs :false

Vue 父子组件数据传递的四种方式( inheritAttrs + $attrs + $listeners)
Vue 父子组件数据传递的四种方式( inheritAttrs + $attrs + $listeners)

inheritAttrs :false

Vue 父子组件数据传递的四种方式( inheritAttrs + $attrs + $listeners)
Vue 父子组件数据传递的四种方式( inheritAttrs + $attrs + $listeners)

c='ture1.png'>

官方解释:默认情况下父作用域的不被认作 props 的特性绑定 ( attribute bindings ) 将会“回退”且作为普通的 HTML 特性应用在子组件的根元素上。当撰写包裹一个目标元素或另一个组件的组件时,这可能不会总是符合预期行为。通过设置 inheritAttrsfalse ,这些默认行为将会被去掉。而通过 (同样是 2.4 新增的) 实例属性 $attrs 可以让这些特性生效,且可以通过 v-bind 显性的绑定到非根元素上。

$attrs

我的解释就是:存放没有被子组件继承的的数据对象;看看图

Vue 父子组件数据传递的四种方式( inheritAttrs + $attrs + $listeners)

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

$listeners

我的理解就是:子组件可以触发父组件的事件(不需要用什么那些麻烦的vuex或者一个空的 Vue 实例作为事件总线,或者又是什么 vm.$on )

Vue 父子组件数据传递的四种方式( inheritAttrs + $attrs + $listeners)

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

总结

以上所述是小编给大家介绍的Vue 父子组件数据传递的四种方式( inheritAttrs + $attrs + $listeners),希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!

Javascript 相关文章推荐
教你如何在 Javascript 文件里使用 .Net MVC Razor 语法
Jul 23 Javascript
js兼容火狐显示上传图片预览效果的方法
May 21 Javascript
JavaScript通过Date-Mask将日期转换成字符串的方法
Jun 04 Javascript
JavaScript中用sort()方法对数组元素进行排序的操作
Jun 09 Javascript
Vue指令的钩子函数使用方法
Mar 20 Javascript
JS中用EL表达式获取上下文参数值的方法
Mar 28 Javascript
JavaScript+H5实现微信摇一摇功能
May 23 Javascript
JavaScript中arguments和this对象用法分析
Aug 08 Javascript
详解为element-ui的Select和Cascader添加弹层底部操作按钮
Feb 07 Javascript
vue+elementUI 实现内容区域高度自适应的示例
Sep 26 Javascript
js+h5 canvas实现图片验证码
Oct 11 Javascript
80行代码写一个Webpack插件并发布到npm
May 24 Javascript
JS模拟实现哈希表及应用详解
May 04 #Javascript
vue地区选择组件教程详解
May 04 #Javascript
Vue 按键修饰符处理事件的方法
May 04 #Javascript
vue mint-ui tabbar变组件使用
May 04 #Javascript
Vue结合Video.js播放m3u8视频流的方法示例
May 04 #Javascript
原生javascript AJAX 三级联动的实现代码
May 04 #Javascript
Vue在页面右上角实现可悬浮/隐藏的系统菜单
May 04 #Javascript
You might like
MySql中正则表达式的使用方法描述
2008/07/30 PHP
提高define性能的php扩展hidef的安装和使用
2011/06/14 PHP
php和javascript之间变量的传递实现代码
2012/12/19 PHP
PHP两种快速排序算法实例
2015/02/15 PHP
php实现通过ftp上传文件
2015/06/19 PHP
mac os快速切换多个PHP版本的方法
2017/03/07 PHP
PHP Laravel 上传图片、文件等类封装
2017/08/16 PHP
php设计模式之职责链模式实例分析【星际争霸游戏案例】
2020/03/27 PHP
关于js注册事件的常用方法
2013/04/03 Javascript
JQuery操作Select的Options的Bug(IE8兼容性视图模式)
2013/04/21 Javascript
JS 两个字符串时间的天数差计算
2013/08/25 Javascript
div+css+js实现无缝滚动类似marquee无缝滚动兼容firefox
2013/08/29 Javascript
基于mouseout和mouseover等类似事件的冒泡问题解决方法
2013/11/18 Javascript
jQuery实现流动虚线框的方法
2015/01/29 Javascript
jQuery通过ajax方法获取json数据不执行success的原因及解决方法
2016/10/15 Javascript
jQuery模拟完美实现经典FLASH导航动画效果【附demo源码下载】
2016/11/09 Javascript
ES6(ECMAScript 6)新特性之模板字符串用法分析
2017/04/01 Javascript
SpringMVC+bootstrap table实例详解
2017/06/02 Javascript
js时间戳与日期格式之间相互转换
2017/12/11 Javascript
使用vue-router与v-if实现tab切换遇到的问题及解决方法
2018/09/07 Javascript
JavaScript基础教程之如何实现一个简单的promise
2018/09/11 Javascript
AngularJS修改model值时,显示内容不变的实例
2018/09/13 Javascript
vue父子模板传值问题解决方法案例分析
2020/02/26 Javascript
react中hook介绍以及使用教程
2020/12/11 Javascript
Python中统计函数运行耗时的方法
2015/05/05 Python
pycharm安装和首次使用教程
2018/08/27 Python
python中if及if-else如何使用
2020/06/02 Python
python实现三壶谜题的示例详解
2020/11/02 Python
客服工作职责
2013/12/11 职场文书
2014年道德讲堂实施方案
2014/03/05 职场文书
个人作风建设剖析材料
2014/10/11 职场文书
张家口市高新区党工委群众路线教育实践活动整改方案
2014/10/25 职场文书
银行稽核岗位职责
2015/04/13 职场文书
2015年银行大堂经理工作总结
2015/04/24 职场文书
Nginx 负载均衡是什么以及该如何配置
2021/03/31 Servers
vue 自定义组件添加原生事件
2022/04/21 Vue.js