详解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 相关文章推荐
扩展jQuery 键盘事件的几个基本方法
Oct 30 Javascript
jquery对表单操作2
Apr 06 Javascript
jQuery源码分析-04 选择器-Sizzle-工作原理分析
Nov 14 Javascript
关于JS管理作用域的问题
Apr 10 Javascript
JS简单实现文件上传实例代码(无需插件)
Nov 15 Javascript
Highcharts 多个Y轴动态刷新数据的实现代码
May 28 Javascript
利用Vue v-model实现一个自定义的表单组件
Apr 27 Javascript
php 修改密码实现代码
May 24 Javascript
Bootstrap Table使用整理(四)之工具栏
Jun 09 Javascript
r.js来合并压缩css文件的示例
Apr 26 Javascript
利用原生的JavaScript实现简单拼图游戏
Nov 18 Javascript
js 计算图片内点个数的示例代码
Apr 04 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创建、获取cookie及基础要点分析
2015/01/26 PHP
PHP实现的装箱算法示例
2018/06/23 PHP
php实现银联商务公众号+服务窗支付的示例代码
2019/10/12 PHP
document.open() 与 document.write()的区别
2007/08/13 Javascript
javascript 多种搜索引擎集成的页面实现代码
2010/01/02 Javascript
jquery键盘事件介绍
2011/01/31 Javascript
Notify - 基于jquery的消息通知插件
2011/10/18 Javascript
jQuery 遍历-nextUntil()方法以及prevUntil()方法的使用介绍
2013/04/26 Javascript
教你用jquery实现iframe自适应高度
2014/06/11 Javascript
JS右下角广告窗口代码(可收缩、展开及关闭)
2015/09/04 Javascript
JS验证邮件地址格式方法小结
2015/12/01 Javascript
JS常见算法详解
2017/02/28 Javascript
JavaScript仿微信打飞机游戏
2020/07/05 Javascript
vue+echarts实现可拖动节点的折线图(支持拖动方向和上下限的设置)
2019/04/12 Javascript
[59:44]2018DOTA2亚洲邀请赛 3.31 小组赛 B组 paiN vs iG
2018/03/31 DOTA
python实现随机密码字典生成器示例
2014/04/09 Python
Python中logging模块的用法实例
2014/09/29 Python
python实现Flappy Bird源码
2018/12/24 Python
Python提取支付宝和微信支付二维码的示例代码
2019/02/15 Python
Pytorch中膨胀卷积的用法详解
2020/01/07 Python
详解css3 Transition属性(平滑过渡菜单栏案例)
2017/09/05 HTML / CSS
FLOS美国官网:意大利高级照明工艺的传奇
2018/08/07 全球购物
怀旧香味蜡烛:Homesick
2019/11/02 全球购物
德国W家官网,可直邮中国的母婴商城:Windeln.de
2021/03/03 全球购物
Linux的主要特性
2016/09/03 面试题
利用promise及参数解构封装ajax请求的方法
2021/03/24 Javascript
酒吧创业计划书
2014/01/18 职场文书
班训口号大全
2014/06/18 职场文书
房地产资料员岗位职责
2014/07/02 职场文书
物业保洁员岗位职责
2015/02/13 职场文书
2014年个人年终总结
2015/03/09 职场文书
python实现简单倒计时功能
2021/04/21 Python
解决Django transaction进行事务管理踩过的坑
2021/04/24 Python
Netty结合Protobuf进行编解码的方法
2021/06/26 Java/Android
SQL SERVER存储过程用法详解
2022/02/24 SQL Server
Vue深入理解插槽slot的使用
2022/08/05 Vue.js