vue组件通信的多种方法详解

2022-04-15 0 298
目录
  • 1. 父传子
  • 2. 子传父
  • 3. 非父子组件传值
  • 4. vuex
  • 5. refs
  • 6. $children
  • 7. $parent
  • 8. provide & inject
  • 9. $attrs
  • 10. $listeners
  • 总结

说起组件通信,可能大家耳熟能详的有以下5种:

1. 父传子

父组件通过自定义属性给子组件传值,子组件用props接收

2. 子传父

父组件在子组件标签上自定义事件,子组件通过$emit来触发自定义事件,并且可以传递参数

3. 非父子组件传值

eventBus事件总线:

可通过eventBus进行信息的发布与订阅(创造一个都能访问到的事件总线)

vue组件通信的多种方法详解

4. vuex

vuex是专为vue.js应用程序开发的状态管理模式,它采用集中式存储管理程序的所有组件的状态,解决多组件通信。不过多用于中大型项目,小型项目用它会显得臃肿。

5. refs

通过添加ref和·$refs·配合,也可以很方便的获取子组件,访问调用子组件的属性和方法
关于refs,我还另外单独写过一篇详细用法的,refs的用法

除开以上5种,还有5种不那么常见的组件通信方法:

6. $children

父组件中·$children·返回的是一个组件集合,如果清楚知道子组件的顺序,也可以使用下标操作

vue组件通信的多种方法详解

7. $parent

子组件中this.$parent指向父组件,子组件无法直接修改父组件中的数据,可以通过this.$parent让父组件自己去改

例如:

this.$parent.xxx=200

this.$parent.fn()

8. provide & inject

成对出现:provide和inject是成对出现的

作用:用于父组件向子孙组件传递数据

使用方法:

  • provide在父组件中,返回要传给下级的数据
  • inject在需要使用这个数据的子孙组件中注入数据。(不论组件层次有多深)

vue组件通信的多种方法详解 

9. $attrs

用于父组件给孙组件传递数据

10. $listeners

用于孙组件给父组件传递数据

vue组件通信的多种方法详解

总结

本篇文章就到这里了,希望能够给你带来帮助,也希望您能够多多关注NICE源码的更多内容!

免责声明:
1、本网站所有发布的源码、软件和资料均为收集各大资源网站整理而来;仅限用于学习和研究目的,您必须在下载后的24个小时之内,从您的电脑中彻底删除上述内容。 不得使用于非法商业用途,不得违反国家法律。否则后果自负!

2、本站信息来自网络,版权争议与本站无关。一切关于该资源商业行为与www.niceym.com无关。
如果您喜欢该程序,请支持正版源码、软件,购买注册,得到更好的正版服务。
如有侵犯你版权的,请邮件与我们联系处理(邮箱:skknet@qq.com),本站将立即改正。

NICE源码网 JavaScript vue组件通信的多种方法详解 https://www.niceym.com/19781.html