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 相关文章推荐
为EasyUI的Tab标签添加右键菜单的方法
Jul 14 Javascript
javascript类型系统——undefined和null全面了解
Jul 13 Javascript
基于vue2.0+vuex+localStorage开发的本地记事本示例
Feb 28 Javascript
jQuery图片瀑布流的简单实现代码
Mar 15 Javascript
微信小程序 es6-promise.js封装请求与处理异步进程
Jun 12 Javascript
AngularJS模态框模板ngDialog的使用详解
May 11 Javascript
vue路由守卫+登录态管理实例分析
May 21 Javascript
JS定义函数的几种常用方法小结
May 23 Javascript
微信小程序仿淘宝热搜词在搜索框中轮播功能
Jan 21 Javascript
小程序跳转H5页面的方法步骤
Mar 06 Javascript
Taro UI框架开发小程序实现左滑喜欢右滑不喜欢效果的示例代码
May 18 Javascript
Vue-cli3生成的Vue项目加载Mxgraph方法示例
May 31 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
德生BCL3000的电路分析和打磨
2021/03/02 无线电
PHP用星号隐藏部份用户名、身份证、IP、手机号等实例
2014/04/08 PHP
PHP简单创建压缩图的方法
2016/08/24 PHP
php-app开发接口加密详解
2018/04/18 PHP
使用PHP访问RabbitMQ消息队列的方法示例
2018/06/06 PHP
PHP远程连接oracle数据库操作实现方法图文详解
2019/04/11 PHP
js 静态动态成员 and 信息的封装和隐藏
2011/05/29 Javascript
jQuery(1.6.3) 中css方法对浮动的实现缺陷分析
2011/09/09 Javascript
javascript操作JSON的要领总结
2012/12/09 Javascript
Jquery为a标签的href赋值实现代码
2013/05/03 Javascript
jquery日历控件实现方法分享
2014/03/07 Javascript
JavaScript中的对象的extensible属性介绍
2014/12/30 Javascript
jquery实现具有嵌套功能的选项卡
2016/02/12 Javascript
深入理解js promise chain
2016/05/05 Javascript
JavaScript ES5标准中新增的Array方法
2016/06/28 Javascript
js enter键激发事件实例代码
2016/08/17 Javascript
JavaScript装饰器函数(Decorator)实例详解
2017/03/30 Javascript
elemetUi 组件--el-upload实现上传Excel文件的实例
2017/10/27 Javascript
Vue中的Vux配置指南
2017/12/08 Javascript
浅谈Webpack多页应用HMR卡住问题
2019/04/24 Javascript
layui实现三级导航菜单
2019/07/26 Javascript
解决layer.open后laydate失效的问题
2019/09/06 Javascript
python爬虫入门教程之点点美女图片爬虫代码分享
2014/09/02 Python
python使用post提交数据到远程url的方法
2015/04/29 Python
使用python调用zxing库生成二维码图片详解
2017/01/10 Python
Python数据类型之Tuple元组实例详解
2019/05/08 Python
python中HTMLParser模块知识点总结
2021/01/25 Python
英国第二大营养品供应商:Vitabiotics
2016/10/01 全球购物
LN-CC英国:伦敦时尚生活的缩影
2019/09/01 全球购物
广州迈达威.net面试题目
2012/03/10 面试题
如何利用find命令查找文件
2016/11/18 面试题
经理管理专业毕业自荐书范文
2014/02/12 职场文书
机关单位人员学雷锋心得体会
2014/03/10 职场文书
计算机网络工程专业职业生涯规划书
2014/03/10 职场文书
致短跑运动员加油稿
2015/07/21 职场文书
Vue深入理解插槽slot的使用
2022/08/05 Vue.js