详解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 相关文章推荐
Document对象内容集合(比较全)
Sep 06 Javascript
使用jQuery fancybox插件打造一个实用的数据传输模态弹出窗体
Jan 15 Javascript
javascript ajax的5种状态介绍
Aug 18 Javascript
javascript中定义类的方法汇总
Dec 28 Javascript
javascript 获取浏览器版本
Jan 21 Javascript
JQuery分屏指示器图片轮换效果实例
May 21 Javascript
js和C# 时间日期格式转换的简单实例
May 28 Javascript
浅析javaScript中的浅拷贝和深拷贝
Feb 15 Javascript
vue实现商城秒杀倒计时功能
Dec 12 Javascript
详解vue-flickity的fullScreen功能实现
Apr 07 Javascript
jquery实现有过渡效果的tab切换
Jul 17 jQuery
vue实现倒计时功能
Mar 24 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 MemCached高级缓存配置图文教程
2010/08/05 PHP
php中使用DOM类读取XML文件的实现代码
2011/12/14 PHP
如何用PHP实现插入排序?
2013/04/10 PHP
php 5.6版本中编写一个PHP扩展的简单示例
2015/01/20 PHP
PHP Opcache安装和配置方法介绍
2015/05/28 PHP
PHP实现Redis单据锁以及防止并发重复写入
2018/04/10 PHP
javascript  Error 对象 错误处理
2008/05/18 Javascript
javascript实现的淘宝旅行通用日历组件用法实例
2015/08/03 Javascript
jQuery获取字符串中出现最多的数
2016/02/22 Javascript
JavaScript实现页面跳转的方式汇总
2016/05/16 Javascript
js 自带的 map() 方法全面了解
2016/08/16 Javascript
bootstrapfileinput实现文件自动上传
2016/11/08 Javascript
详解Html a标签中href和onclick用法、区别、优先级别
2017/01/16 Javascript
js中Number数字数值运算后值不对的解决方法
2017/02/28 Javascript
从零开始学习Node.js系列教程四:多页面实现的数学运算示例
2017/04/13 Javascript
JavaScript算法教程之sku(库存量单位)详解
2017/06/29 Javascript
vue中手机号,邮箱正则验证以及60s发送验证码的实例
2018/03/16 Javascript
Bootbox将后台JSON数据填充Form表单的实例代码
2018/09/10 Javascript
100行代码实现一个vue分页组功能
2018/11/06 Javascript
查找Vue中下标的操作(some和findindex)
2020/08/12 Javascript
详解在Python和IPython中使用Docker
2015/04/28 Python
详解Python中的序列化与反序列化的使用
2015/06/30 Python
Django中使用CORS实现跨域请求过程解析
2019/08/05 Python
Python (Win)readline和tab补全的安装方法
2019/08/27 Python
Django实现将views.py中的数据传递到前端html页面,并展示
2020/03/16 Python
Python打印不合法的文件名
2020/07/31 Python
ColourPop美国官网:卡拉泡泡,洛杉矶彩妆品牌
2019/04/28 全球购物
Sport-Thieme荷兰:购买体育用品
2019/08/25 全球购物
eBay意大利购物网站:eBay.it
2019/09/04 全球购物
机电一体化专业应届本科生求职信
2013/09/27 职场文书
秘书英文求职信范文
2014/01/31 职场文书
2014年9.18纪念日演讲稿
2014/09/14 职场文书
教师自我剖析材料(群众路线)
2014/09/29 职场文书
2015中学学校工作总结
2015/07/20 职场文书
初中生入团申请书范文(五篇)
2019/10/16 职场文书
十大最强飞行系宝可梦,BUG燕上榜,第二是飞行系王者
2022/03/18 日漫