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处理解析JSON数据过程详解
Sep 11 Javascript
javascript实现label标签跳出循环操作
Mar 06 Javascript
JS中如何比较两个Json对象是否相等实例代码
Jul 13 Javascript
jQuery实现select模糊查询(反射机制)
Jan 14 Javascript
javascript中递归的两种写法
Jan 17 Javascript
十大 Node.js 的 Web 框架(快速提升工作效率)
Jun 30 Javascript
Vue头像处理方案小结
Jul 26 Javascript
详解基于iview-ui的导航栏路径(面包屑)配置
Feb 22 Javascript
迅速了解一下ES10中Object.fromEntries的用法使用
Mar 05 Javascript
Mpvue中使用Vant Weapp组件库的方法步骤
May 16 Javascript
关于vue3.0中的this.$router.replace({ path: '/'})刷新无效果问题
Jan 16 Javascript
解决vue2中使用elementUi打包报错的问题
Sep 22 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
基于mysql的论坛(7)
2006/10/09 PHP
php设计模式 DAO(数据访问对象模式)
2011/06/26 PHP
让firefox支持IE的一些方法的javascript扩展函数代码
2010/01/02 Javascript
JS onmousemove鼠标移动坐标接龙DIV效果实例
2013/12/16 Javascript
不同编码的页面表单数据乱码问题解决方法
2015/02/15 Javascript
jQuery.Highcharts.js绘制柱状图饼状图曲线图
2015/03/14 Javascript
jQuery使用hide方法隐藏元素自身用法实例
2015/03/30 Javascript
浅谈js 闭包引起的内存泄露问题
2015/06/22 Javascript
跟我学习javascript的基本类型和引用类型
2015/11/16 Javascript
js滚动条平滑移动示例代码
2016/03/29 Javascript
Bootstrap Chart组件使用教程
2016/04/28 Javascript
深入理解ECMAScript的几个关键语句
2016/06/01 Javascript
微信小程序入门教程
2016/11/18 Javascript
vue 2.0路由之路由嵌套示例详解
2017/05/08 Javascript
D3.js 实现带伸缩时间轴拓扑图的示例代码
2020/01/20 Javascript
selenium 反爬虫之跳过淘宝滑块验证功能的实现代码
2020/08/27 Javascript
详解JavaScript执行模型
2020/11/16 Javascript
Windows下实现Python2和Python3两个版共存的方法
2015/06/12 Python
纯python实现机器学习之kNN算法示例
2018/03/01 Python
python 处理string到hex脚本的方法
2018/10/26 Python
Python3 log10()函数简单用法
2019/02/19 Python
Python传递参数的多种方式(小结)
2019/09/18 Python
Django关于admin的使用技巧和知识点
2020/02/10 Python
Python requests模块基础使用方法实例及高级应用(自动登陆,抓取网页源码)实例详解
2020/02/14 Python
HTML5实现可缩放时钟代码
2017/08/28 HTML / CSS
波比布朗英国官网:Bobbi Brown英国
2017/11/13 全球购物
美国家居装饰网上商店:Lulu & Georgia
2019/09/14 全球购物
大专生自荐信
2013/10/04 职场文书
土木工程专业大学毕业生求职信
2013/10/13 职场文书
个人应聘自我评价分享
2013/11/18 职场文书
小学红领巾广播稿(3篇)
2014/09/13 职场文书
县委务虚会发言材料
2014/10/20 职场文书
2015年财政所工作总结
2015/04/25 职场文书
交通事故责任认定书
2015/08/06 职场文书
2019客服个人年终工作总结范文
2019/07/08 职场文书
MySQL库表名大小写的选择
2021/06/05 MySQL