vue组件之间的数据传递方法详解


Posted in Javascript onApril 19, 2019

(1)props属性:

在父组件中,可以通过子组件标签属性的形式将数据或者函数传给子组件,子组件通过props去读取父组件传过来的数据

用法

父组件传数据给子组件:

  1. 一般的属性值都是用来给子组件展示的

子组件传数据给父组件

  1. 属性值为函数类型的,一般是用来子组件向父组件传递数据,子组件通过调用父组件传过来的函数,可以修改父组件的状态数据

缺点:

  1. 隔层组件间传递: 必须逐层传递(麻烦)
  2. 兄弟组件间: 必须借助父组件(麻烦)

注意:

//子组件获取父组件传过来的值
props: {
  obj: {//obj为{id:'2'}
    type: Object 
  }
}

引用类型的props,我们可以在子组件中直接修改引用类型属性的值(如:this.obj.id='3',会生效),但是不能直接改变引用类型存储的地址值(如:this.obj = {id: '3'}),会发出警告。

虽然子组件可以直接修改父组件的状态值,但我们不建议这样做,我们希望所有的 prop 都使得其父子 prop 之间形成了一个单向下行绑定:父级 prop 的更新会向下流动到子组件中,但是反过来则不行。这样会防止从子组件意外改变父级组件的状态,从而导致你的应用的数据流向难以理解。

(2)vue自定义事件:

方式1: 给子组件标签绑定事件监听

子组件向父组件的通信方式

功能类似于function props

通过在父组件中给子组件标签绑定自定义事件的监听,再由子组件触发事件,实现子组件向父组件传递数据的方法,事件名必须一致,且不能有大写字母,v-on 事件监听器在 DOM 模板中会被自动转换为全小写 (因为 HTML 是大小写不敏感的)

// 方式一: 通过v-on绑定
<component @delete_todo="deleteTodo"/>
// 方式二: 通过$on()绑定
this.$refs.xxx.$on('delete_todo', function (todo) {
this.deleteTodo(todo)
})

通过this.$emit('delete_todo', todo)触发事件

不适合隔层组件和兄弟组件间的通信

方式2: 通过单独的vm对象绑定监听/分发事件

任意组件间通信(类似于pubsub)

创建一个公用的vm对象

import Vue from 'vue'

export default new Vue()

在接收消息的组件,绑定监听

import vm from './vm.js'

mounted(){
  vm.$on('delete_todo', function (todo) {
		this.deleteTodo(todo)
	})
}

在发送消息的组件,触发事件

vm.$emit('delete_todo', todo)

(3) 消息的订阅和发布(pubsub)

适用于任何关系的组件间的通信
缺点:相对于vuex,管理不够集中
用法:

引入pubsub-js库
在接收消息的组件订阅消息(subscribe)
在发送消息的组件发布消息 ( publish)

(4)vuex

多组件共享状态(数据的管理)
组件间的关系也没有限制
功能比pubsub强大, 更适用于vue项目

(5) slot

父向子通信
通信是带数据的标签
注意: 标签是在父组件中解析

以上所述是小编给大家介绍的vue组件之间的数据传递方法详解整合,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!

Javascript 相关文章推荐
Javascript 按位取反运算符 (~)
Feb 04 Javascript
JavaScript获取function所有参数名的方法
Oct 30 Javascript
详解javascript中的事件处理
Nov 06 Javascript
JavaScript数据结构与算法之链表
Jan 29 Javascript
浅析jQuery Ajax请求参数和返回数据的处理
Feb 24 Javascript
JavaScript数据操作_浅谈原始值和引用值的操作本质
Aug 23 Javascript
微信小程序页面间通信的5种方式
Mar 31 Javascript
ES6中javascript实现函数绑定及类的事件绑定功能详解
Nov 08 Javascript
解决vue 中 echart 在子组件中只显示一次的问题
Aug 07 Javascript
Bootstrap Table实现定时刷新数据的方法
Aug 13 Javascript
小程序扫描普通链接二维码跳转小程序指定界面方法
May 07 Javascript
解决Vue+Electron下Vuex的Dispatch没有效果问题
May 20 Javascript
详解keep-alive + vuex 让缓存的页面灵活起来
Apr 19 #Javascript
一个Java程序猿眼中的前后端分离以及Vue.js入门(推荐)
Apr 19 #Javascript
基于javascript的拖拽类封装详解
Apr 19 #Javascript
Bootstarp在pycharm中的安装及简单的使用方法
Apr 19 #Javascript
Vue Cli 3项目使用融云IM实现聊天功能的方法
Apr 19 #Javascript
详解vue-cli+es6引入es5写的js(两种方法)
Apr 19 #Javascript
vue中使用vue-cli接入融云实现即时通信
Apr 19 #Javascript
You might like
雄兵连三大错觉:凯莎没了,凉冰阵亡了,华烨觉得自己又行了
2020/04/09 国漫
PHP数组循环操作详细介绍 附实例代码
2013/02/03 PHP
ThinkPHP中I(),U(),$this-&gt;post()等函数用法
2014/11/22 PHP
php仿微信红包分配算法的实现方法
2016/05/13 PHP
PHP批量删除jQuery操作
2017/07/23 PHP
javascript 建设银行登陆键盘
2008/06/10 Javascript
Jquery中的CheckBox、RadioButton、DropDownList的取值赋值实现代码
2011/10/12 Javascript
js控制鼠标事件移动及移出效果显示
2014/10/19 Javascript
node.js中的socket.io的广播消息
2014/12/15 Javascript
详解如何在NodeJS项目中优雅的使用ES6
2017/04/22 NodeJs
jQuery Validate 校验多个相同name的方法
2017/05/18 jQuery
详解Vue中一种简易路由传参办法
2017/09/15 Javascript
jQuery实现右侧抽屉式在线客服功能
2017/12/25 jQuery
JS简单实现查看文档创建日期、修改日期和文档大小的方法示例
2018/04/08 Javascript
记一次webapck4 配置文件无效的解决历程
2018/09/19 Javascript
vue路由事件beforeRouteLeave及组件内定时器的清除方法
2018/09/29 Javascript
trackingjs+websocket+百度人脸识别API实现人脸签到
2018/11/26 Javascript
express框架中使用jwt实现验证的方法
2019/08/25 Javascript
解决Antd Table组件表头不对齐的问题
2020/10/27 Javascript
python正则表达式抓取成语网站
2013/11/20 Python
Python中文字符串截取问题
2015/06/15 Python
浅谈Python数据类型判断及列表脚本操作
2016/11/04 Python
python 平衡二叉树实现代码示例
2018/07/07 Python
python滑块验证码的破解实现
2019/11/10 Python
Python3运算符常见用法分析
2020/02/14 Python
python中字典增加和删除使用方法
2020/09/30 Python
Python confluent kafka客户端配置kerberos认证流程详解
2020/10/12 Python
Python join()函数原理及使用方法
2020/11/14 Python
利用简洁的图片预加载组件提升html5移动页面的用户体验
2016/03/11 HTML / CSS
IWOOT美国:新奇的小玩意
2018/04/27 全球购物
法国二手手袋、手表和奢侈珠宝购物网站:Collector Square
2018/07/05 全球购物
英国花园、DIY、电器和家居用品商店:Robert Dyas
2019/03/18 全球购物
Fabletics官网:美国运动服饰品牌,由好莱坞女演员凯特·哈德森创立
2019/10/19 全球购物
都柏林通行卡/城市通票:The Dublin Pass
2020/02/16 全球购物
端午节演讲稿
2014/05/23 职场文书
2015大学生入党个人自传
2015/06/26 职场文书