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 相关文章推荐
Prototype Array对象 学习
Jul 19 Javascript
浅谈Javascript事件处理程序的几种方式
Jun 27 Javascript
js从10种颜色中随机取色实现每次取出不同的颜色
Oct 23 Javascript
构造函数+原型模式构造js自定义对象(最通用)
May 12 Javascript
在JavaScript应用中实现延迟加载的方法
Jun 25 Javascript
浅析Bootstrip的select控件绑定数据的问题
May 10 Javascript
jQuery Ajax向服务端传递数组参数值的实例代码
Sep 03 jQuery
Vue.js实现可配置的登录表单代码详解
Mar 29 Javascript
layui使用数据表格实现购物车功能
Jul 26 Javascript
如何换个角度使用VUE过滤器详解
Sep 11 Javascript
Vue CLI3移动端适配(px2rem或postcss-plugin-px2rem)
Apr 27 Javascript
vue中用 async/await 来处理异步操作
Jul 18 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支持页面回退的两种方法
2008/01/10 PHP
关于php curl获取301或302转向的网址问题的解决方法
2011/06/02 PHP
php中echo()和print()、require()和include()等易混淆函数的区别
2012/02/22 PHP
php获取apk包信息的方法
2014/08/15 PHP
Yii获取当前url和域名的方法
2015/06/08 PHP
thinkphp3.x中display方法及show方法的用法实例
2016/05/19 PHP
PHP中多线程的两个实现方法
2016/10/14 PHP
thinkPHP+ajax实现统计页面pv浏览量的方法
2017/03/15 PHP
ThinkPHP框架获取最后一次执行SQL语句及变量调试简单操作示例
2018/06/13 PHP
PHP的mysqli_set_charset()函数讲解
2019/01/23 PHP
javascript 原型模式实现OOP的再研究
2009/04/09 Javascript
Jquery 一次处理多个ajax请求的代码
2011/09/02 Javascript
jQuery EasyUI API 中文文档 - ValidateBox验证框
2011/10/06 Javascript
S2SH整合JQuery+Ajax实现登录验证功能实现代码
2013/01/30 Javascript
JavaSript中变量的作用域闭包的深入理解
2014/05/12 Javascript
javascript中的return和闭包函数浅析
2014/06/06 Javascript
jQuery.prop() 使用详解
2015/07/19 Javascript
JavaScript调用客户端Java程序的方法
2015/07/27 Javascript
javascript制作幻灯片(360度全景图片)
2015/07/28 Javascript
jquery animate动画持续运动的实例
2017/11/29 jQuery
利用原生JavaScript实现造日历轮子实例代码
2019/05/08 Javascript
记录微信小程序 height: calc(xx - xx);无效问题
2019/12/30 Javascript
uniapp与webview之间的相互传值的实现
2020/06/29 Javascript
numpy中索引和切片详解
2017/12/15 Python
Python+OpenCV实现图像融合的原理及代码
2018/12/03 Python
浅谈python3.6的tkinter运行问题
2019/02/22 Python
python实现淘宝购物系统
2019/10/25 Python
在Django中实现添加user到group并查看
2019/11/18 Python
Win10用vscode打开anaconda环境中的python出错问题的解决
2020/05/25 Python
Marks & Spencer爱尔兰:英国马莎百货
2016/04/20 全球购物
教师开学感言
2014/02/14 职场文书
文明倡议书范文
2014/04/15 职场文书
兴趣小组活动总结
2014/05/05 职场文书
会计专业自荐书
2014/07/08 职场文书
运动会广播稿50字
2015/08/19 职场文书
优秀毕业生主要事迹材料
2015/11/04 职场文书