详解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 使用个人心得
Feb 26 Javascript
JQuery jsonp 使用示例代码
Aug 12 Javascript
JQuery1.6 使用方法三
Nov 23 Javascript
用正则表达式替换图片地址img标签
Nov 22 Javascript
jQuery+css3实现转动的正方形效果(附demo源码下载)
Jan 27 Javascript
使用JavaScript实现ajax的实例代码
May 11 Javascript
javascript事件捕获机制【深入分析IE和DOM中的事件模型】
Dec 15 Javascript
微信小程序 websocket 实现SpringMVC+Spring+Mybatis
Aug 04 Javascript
vue使用ajax获取后台数据进行显示的示例
Aug 09 Javascript
Node使用Selenium进行前端自动化操作的代码实现
Oct 10 Javascript
JS严格模式原理与用法实例分析
Apr 27 Javascript
Vue 实现可视化拖拽页面编辑器
Feb 01 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 中英文语言转换类代码
2011/08/11 PHP
php中利用explode函数分割字符串到数组
2014/02/08 PHP
PHP+Mysql+jQuery文件下载次数统计实例讲解
2015/10/10 PHP
PHP chop()函数讲解
2019/02/11 PHP
YII2框架中使用RBAC对模块,控制器,方法的权限控制及规则的使用示例
2020/03/18 PHP
图片onload事件触发问题解决方法
2011/07/31 Javascript
js限制文本框只能输入数字(正则表达式)
2012/07/15 Javascript
在新窗口打开超链接的方法小结
2013/04/14 Javascript
Jquery 改变radio/checkbox选中状态,获取选中的值(示例代码)
2013/12/12 Javascript
Angularjs分页查询的实现
2017/02/24 Javascript
对angular4子路由&辅助路由详解
2018/10/09 Javascript
Vue列表如何实现滚动到指定位置样式改变效果
2020/05/09 Javascript
封装Vue Element的table表格组件的示例详解
2020/08/19 Javascript
[59:53]DOTA2-DPC中国联赛 正赛 VG vs Elephant BO3 第二场 3月6日
2021/03/11 DOTA
Python操作MySQL简单实现方法
2015/01/26 Python
微信 用脚本查看是否被微信好友删除
2016/10/28 Python
python 第三方库的安装及pip的使用详解
2017/05/11 Python
Python中模块pymysql查询结果后如何获取字段列表
2017/06/05 Python
Python学习教程之常用的内置函数大全
2017/07/14 Python
Python装饰器用法示例小结
2018/02/11 Python
简单谈谈Python的pycurl模块
2018/04/07 Python
Python爬取数据并写入MySQL数据库的实例
2018/06/21 Python
对python字典元素的添加与修改方法详解
2018/07/06 Python
python利用Opencv实现人脸识别功能
2019/04/25 Python
python生成requirements.txt的两种方法
2019/09/18 Python
详解Django中的FBV和CBV对比分析
2021/03/01 Python
css3一款3D字体带阴影效果的实现步骤
2013/03/20 HTML / CSS
iRobot官网:改变生活的家用机器人品牌
2016/09/20 全球购物
GANT葡萄牙官方商店:拥有美国运动服传统的生活方式品牌
2018/10/18 全球购物
德国汽车零件和汽车配件网上商店:kfzteile24
2018/11/14 全球购物
int *p=NULL和*p= NULL有什么区别
2014/10/23 面试题
前台文员个人求职信范文
2014/01/05 职场文书
2015年七一建党节活动总结
2015/03/20 职场文书
医者仁心观后感
2015/06/17 职场文书
行政复议答复书
2015/07/01 职场文书
捐款仪式主持词
2015/07/04 职场文书