详解Vue中组件传值的多重实现方式


Posted in Javascript onAugust 16, 2019

vue中组件传值方式整理

1.我们最熟悉的父子组件传值

父->子 props
 子->父 $emit

这些我们最常用的就不说了,如果有不理解的,俺这儿有篇不错的文章,链接奉上~

https://www.cnblogs.com/LoveAndPeace/p/7273648.html

2.兄弟组件或无关系组件之间的传值

我们最常用的方式采用一个第三方变量 俗称eventbus
  通过其中一个$emit发另一个$on接收的方式 实现组件传值
  
  main.js中挂载一下

详解Vue中组件传值的多重实现方式

在其中一个页面$emit

详解Vue中组件传值的多重实现方式

另一个页面$on

详解Vue中组件传值的多重实现方式

是不是有点像昨天我写的pubsub呢?哈哈哈哈哈

3.attr和listener进行传值(注意,这两种只能向下传递)

父组件里的子组件上写上你要传递的键名键值,

详解Vue中组件传值的多重实现方式

子组件里通过{{$attrs}}拿到你所有传递的值

详解Vue中组件传值的多重实现方式

这样直接就拿到了,是不是很神奇~

效果:

详解Vue中组件传值的多重实现方式

子组件里通过{{$attrs}}拿到你所有传递的值

子组件下边还有组件 可以用v-bind:"$attrs"传递,在孙子组件中通过{{$attrs}}

详解Vue中组件传值的多重实现方式

listener用来传递事件,用法大致一个样

详解Vue中组件传值的多重实现方式

我们设置一个点击事件

在子元素中↓我们console下,看看拿到没有

详解Vue中组件传值的多重实现方式

详解Vue中组件传值的多重实现方式

再笼统的概述下
  vue中 listeners事件传递
父组件里的子组件上写个函数 比如@log="log",在当前页的methods:{}里对应上执行的语句
子组件触发的话里写个触发事件,如click="aaa" 
methods写法:
methods:{
 aaa(){
  this.$listeners.你父组件的那个方法 这里是this.$listeners.log()调用
 }
}

子组件下还有组件的话 用v-on:"$listeners"再往下传
下面继续用子组件获取的方法获取

4.采用ref的方式 有点react父传子的亚子

but!也不太一样 ,在你父组件引入的子组件上写个ref="xxx",你父组件便拿到了一系列子组件的东西,比如数据,事件等↓

详解Vue中组件传值的多重实现方式

详解Vue中组件传值的多重实现方式

5.用vuex 就不用说了吧 数据集中起来,每个页面值都能相互拿到

state里设置值

通过stor.state.值拿到值

通过commit 或者dispatch往mutations和actions里提交可以做数据对应处理等等....

6.通过provide设置,inject取值但是这种方式不建议用

举个栗子:

详解Vue中组件传值的多重实现方式

另一个组件

详解Vue中组件传值的多重实现方式

搞定~ 这是整理的一些组件传值的方法,初来乍到许多写文的格式不太会调,大家凑合看

总结

以上所述是小编给大家介绍的Vue中组件传值的多重实现方式,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!
如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!

Javascript 相关文章推荐
ie focus bug 解决方法
Sep 03 Javascript
Javascript仿PHP $_GET获取URL中的参数
May 12 Javascript
Javascript实现快速排序(Quicksort)的算法详解
Sep 06 Javascript
浅析angularJS中的ui-router和ng-grid模块
May 20 Javascript
JS类的定义与使用方法深入探索
Nov 26 Javascript
Angular.js中angular-ui-router的简单实践
Jul 18 Javascript
利用纯JS实现像素逐渐显示的方法示例
Aug 14 Javascript
详解vuex中mapState,mapGetters,mapMutations,mapActions的作用
Apr 13 Javascript
原生js实现form表单序列化的方法
Aug 02 Javascript
vue 循环加载数据并获取第一条记录的方法
Sep 26 Javascript
解决Vue的文本编辑器 vue-quill-editor 小图标样式排布错乱问题
Aug 03 Javascript
vue使用transition组件动画效果的实例代码
Jan 28 Vue.js
详解vue+axios给开发环境和生产环境配置不同的接口地址
Aug 16 #Javascript
JavaScript JSON数据处理全集(小结)
Aug 15 #Javascript
JointJS JavaScript流程图绘制框架解析
Aug 15 #Javascript
基于vue写一个全局Message组件的实现
Aug 15 #Javascript
vue element-ui table组件动态生成表头和数据并修改单元格格式 父子组件通信
Aug 15 #Javascript
解决vuex刷新状态初始化的方法实现
Aug 15 #Javascript
超详细的5个Shell脚本实例分享(值得收藏)
Aug 15 #Javascript
You might like
php 深入理解strtotime函数的使用详解
2013/05/23 PHP
Linux中用PHP判断程序运行状态的2个方法
2014/05/04 PHP
分享php分页的功能模块
2015/06/16 PHP
Laravel5.1 框架Request请求操作常见用法实例分析
2020/01/04 PHP
Google韩国首页图标动画效果
2007/08/26 Javascript
javascript相等运算符与等同运算符详细介绍
2013/11/09 Javascript
JQ中$(window).load和$(document).ready区别与执行顺序
2017/03/01 Javascript
JS验证全角与半角及相互转化的介绍
2017/05/18 Javascript
详细介绍RxJS在Angular中的应用
2017/09/23 Javascript
ejsExcel模板在Vue.js项目中的实际运用
2018/01/27 Javascript
vue input输入框模糊查询的示例代码
2018/05/22 Javascript
如何在微信小程序中实现Mixins方案
2019/06/20 Javascript
微信小程序从注册账号到上架(图文详解)
2019/07/17 Javascript
详解Vue的ref特性的使用
2020/01/24 Javascript
JavaScript代理模式原理与用法实例详解
2020/03/10 Javascript
js实现数据导出为EXCEL(支持大量数据导出)
2020/03/31 Javascript
如何在vue中使用video.js播放m3u8格式的视频
2021/02/01 Vue.js
Python操作Mysql实例代码教程在线版(查询手册)
2013/02/18 Python
python的dict,set,list,tuple应用详解
2014/07/24 Python
Python中的with语句与上下文管理器学习总结
2016/06/28 Python
关于Python元祖,列表,字典,集合的比较
2017/01/06 Python
Python实现两款计算器功能示例
2017/12/19 Python
python之pandas用法大全
2018/03/13 Python
利用pyinstaller将py文件打包为exe的方法
2018/05/14 Python
python中return的返回和执行实例
2019/12/24 Python
Bibloo奥地利:购买女装、男装、童装、鞋和配件
2018/10/18 全球购物
广州一家公司的.NET面试题
2016/06/11 面试题
工程专业应届生求职信
2014/02/19 职场文书
人资专员岗位职责
2014/04/04 职场文书
团队会宣传标语
2014/10/09 职场文书
催款律师函范文
2015/05/27 职场文书
呼兰河传读书笔记
2015/06/30 职场文书
宿舍管理制度范本
2015/08/07 职场文书
计算机教师工作总结
2015/08/13 职场文书
MySQL中几种插入和批量语句实例详解
2021/09/14 MySQL
Python 多线程处理任务实例
2021/11/07 Python