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 相关文章推荐
15个常用的jquery代码片段
Dec 19 Javascript
jQuery原理系列-常用Dom操作详解
Jun 07 Javascript
jQuery处理XML文件的几种方法
Jun 14 Javascript
简单模拟node.js中require的加载机制
Oct 27 Javascript
Bootstrap table简单使用总结
Feb 15 Javascript
Jquery EasyUI $.Parser
Jun 02 jQuery
JS实现websocket长轮询实时消息提示的效果
Oct 10 Javascript
使用mint-ui实现省市区三级联动效果的示例代码
Feb 09 Javascript
微信小程序时间控件picker view使用详解
Dec 28 Javascript
分享Angular http interceptors 拦截器使用(推荐)
Nov 10 Javascript
jquery html添加元素/删除元素操作实例详解
May 20 jQuery
JavaScript中的LHS和RHS分析详情
Apr 06 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
php+mysql开源XNA 聚合程序发布 下载
2007/07/13 PHP
很好用的PHP数据库类
2009/05/27 PHP
PHP PDO函数库详解
2010/04/27 PHP
php方法调用模式与函数调用模式简例
2011/09/20 PHP
php ctype函数中文翻译和示例
2014/03/21 PHP
用 Javascript 验证表单(form)中多选框(checkbox)值
2009/09/08 Javascript
javascript 自定义回调函数示例代码
2014/09/26 Javascript
基于BootStrap Metronic开发框架经验小结【八】框架功能总体界面介绍
2016/05/12 Javascript
js继承实现方法详解
2016/12/16 Javascript
折叠菜单及选择器的运用
2017/02/03 Javascript
jQuery Pagination分页插件使用方法详解
2017/02/28 Javascript
Vuex模块化实现待办事项的状态管理
2017/03/15 Javascript
JQuery Ajax动态加载Table数据的实例讲解
2018/08/09 jQuery
p5.js实现故宫橘猫赏秋图动画
2019/10/23 Javascript
ant-design-vue 实现表格内部字段验证功能
2019/12/16 Javascript
小程序实现可拖动的悬浮按钮
2020/09/07 Javascript
[03:27]《辉夜杯》线下训练营 导师CU和海涛指点迷津
2015/10/23 DOTA
Python tempfile模块学习笔记(临时文件)
2014/05/25 Python
Python写的Discuz7.2版faq.php注入漏洞工具
2014/08/06 Python
提升Python程序运行效率的6个方法
2015/03/31 Python
Python使用正则表达式获取网页中所需要的信息
2018/01/29 Python
详解Python使用Plotly绘图工具,绘制甘特图
2019/04/02 Python
打包python 加icon 去掉cmd黑窗口方法
2019/06/24 Python
Python-split()函数实例用法讲解
2020/12/18 Python
python字典与json转换的方法总结
2020/12/28 Python
python上下文管理的使用场景实例讲解
2021/03/03 Python
初三化学教学反思
2014/01/23 职场文书
运动会演讲稿100字
2014/08/25 职场文书
七一讲话心得体会
2014/09/05 职场文书
工伤事故赔偿协议书(标准)
2014/09/29 职场文书
初婚初育证明范本
2015/06/18 职场文书
小学教师见习总结
2015/06/23 职场文书
2016大学生暑期三下乡心得体会
2016/01/23 职场文书
导游词之泉州崇武古城
2019/12/20 职场文书
go语言中切片与内存复制 memcpy 的实现操作
2021/04/27 Golang
JavaScript 定时器详情
2021/11/11 Javascript