详解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 相关文章推荐
使Ext的Template可以解析二层的json数据的方法
Dec 22 Javascript
javascript小组件 原生table排序表格脚本(兼容ie firefox opera chrome)
Jul 25 Javascript
为JS扩展Array.prototype.indexOf引发的问题及解决办法
Jan 21 Javascript
jQuery实现ajax的叠加和停止(终止ajax请求)
Aug 08 Javascript
webpack+vue.js实现组件化详解
Oct 12 Javascript
js正则表达式最长匹配(贪婪匹配)和最短匹配(懒惰匹配)用法分析
Dec 27 Javascript
Js自动截取字符串长度,添加省略号(……)的实现方法
Mar 06 Javascript
Swiper 4.x 使用方法(移动端网站的内容触摸滑动)
May 17 Javascript
详解vue-loader在项目中是如何配置的
Jun 04 Javascript
layui实现checkbox的目录树tree的例子
Sep 12 Javascript
vue-cli3 引入 font-awesome的操作
Aug 11 Javascript
ant-design-vue中的select选择器,对输入值的进行筛选操作
Oct 24 Javascript
详解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设计模式 php实现单例模式(singleton)
2015/12/07 PHP
alert中断settimeout计时功能
2013/07/26 Javascript
JS中getYear()和getFullYear()区别分析
2014/07/04 Javascript
js的image onload事件使用遇到的问题
2014/07/15 Javascript
angularJS 中$attrs方法使用指南
2015/02/09 Javascript
jQuery实现伸展与合拢panel的方法
2015/04/30 Javascript
JavaScript中的Math.sin()方法使用详解
2015/06/15 Javascript
jQuery学习笔记之Ajax用法实例详解
2015/12/01 Javascript
jQuery实现打开页面渐现效果示例
2016/07/27 Javascript
yarn的使用与升级Node.js的方法详解
2017/06/04 Javascript
JS实现键值对遍历json数组功能示例
2018/05/30 Javascript
Makefile/cmake/node-gyp中区分判断不同平台的方法
2018/12/18 Javascript
vue实现微信分享链接添加动态参数的方法
2019/04/29 Javascript
Jquery实现获取子元素的方法分析
2019/08/24 jQuery
Nautil 中使用双向数据绑定的实现
2019/10/02 Javascript
vue cli3适配所有端方案的实现
2020/04/13 Javascript
解决elementui表格操作列自适应列宽
2020/12/28 Javascript
[04:10]DOTA2英雄梦之声_第11期_圣堂刺客
2014/06/21 DOTA
[02:15]2014DOTA2国际邀请赛 专访LGD.lin小兔子是大腿
2014/07/14 DOTA
Python httplib,smtplib使用方法
2008/09/06 Python
探究python中open函数的使用
2016/03/01 Python
python 采集中文乱码问题的完美解决方法
2016/09/27 Python
python实现协同过滤推荐算法完整代码示例
2017/12/15 Python
python实现两个文件合并功能
2018/04/01 Python
Python中的上下文管理器和with语句的使用
2018/04/17 Python
Python实现的计算器功能示例
2018/04/26 Python
python之拟合的实现
2019/07/19 Python
高级运动鞋:GREATS
2019/07/19 全球购物
介绍一下Make? 为什么使用make
2013/12/08 面试题
专科文秘应届生求职信
2013/11/18 职场文书
爱岗敬业演讲稿
2014/05/05 职场文书
文明演讲稿范文
2014/05/12 职场文书
2014年学生会个人工作总结
2014/11/07 职场文书
2014年党员发展工作总结
2014/12/02 职场文书
本科毕业论文答辩稿
2015/06/23 职场文书
【js设计模式】SOLID五大设计原则
2022/03/24 Javascript