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中的变量声明早于赋值分析
Mar 01 Javascript
Javascript selection的兼容性写法介绍
Dec 20 Javascript
jQuery CSS()方法改变现有的CSS样式
Aug 20 Javascript
js实现匹配时换色的输入提示特效代码
Aug 17 Javascript
Bootstrap导航栏各元素操作方法(表单、按钮、文本)
Dec 28 Javascript
JS简单实现仿百度控制台输出信息效果
Sep 04 Javascript
react-native-fs实现文件下载、文本存储的示例代码
Sep 22 Javascript
Vue2.0实现调用摄像头进行拍照功能 exif.js实现图片上传功能
Apr 28 Javascript
js数据类型检测总结
Aug 05 Javascript
微信小程序实现富文本图片宽度自适应的方法
Jan 20 Javascript
9102年webpack4搭建vue项目的方法步骤
Feb 20 Javascript
JavaScript页面倒计时功能完整示例
May 15 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基于堆栈实现的高级计算器功能示例
2017/09/15 PHP
php进程daemon化的正确实现方法
2018/09/06 PHP
PHP实现字符串大小写转函数的功能实例
2019/02/06 PHP
使用不同的方法结合/合并两个JS数组
2014/09/18 Javascript
关于js里的this关键字的理解
2015/08/17 Javascript
jQuery实现的分子运动小球碰撞效果
2016/01/27 Javascript
详解angular2封装material2对话框组件
2017/03/03 Javascript
node操作mysql数据库实例详解
2017/03/17 Javascript
webpack多页面开发实践
2017/12/18 Javascript
vue+vue-router转场动画的实例代码
2018/09/01 Javascript
node.js调用C++函数的方法示例
2018/09/21 Javascript
el-select 下拉框多选实现全选的实现
2019/08/02 Javascript
小程序识别身份证,银行卡,营业执照,驾照的实现
2019/11/05 Javascript
微信小程序地图绘制线段并且测量(实例代码)
2020/01/02 Javascript
jquery实现抽奖功能
2020/10/22 jQuery
ES6字符串的扩展实例
2020/12/21 Javascript
[02:29]完美世界高校联赛上海赛区回顾
2015/12/15 DOTA
Python基于回溯法子集树模板解决m着色问题示例
2017/09/07 Python
python中Apriori算法实现讲解
2017/12/10 Python
关于Django显示时间你应该知道的一些问题
2017/12/25 Python
Django框架创建mysql连接与使用示例
2019/07/29 Python
Pytorch Tensor 输出为txt和mat格式方式
2020/01/03 Python
Python requests模块基础使用方法实例及高级应用(自动登陆,抓取网页源码)实例详解
2020/02/14 Python
15行Python代码实现免费发送手机短信推送消息功能
2020/02/27 Python
基于pycharm实现批量修改变量名
2020/06/02 Python
Python爬虫谷歌Chrome F12抓包过程原理解析
2020/06/04 Python
MCAKE蛋糕官方网站:一直都是巴黎的味道
2018/02/06 全球购物
西班牙高科技产品购物网站:MejorDeseo
2019/09/08 全球购物
MYSQL相比于其他数据库有哪些特点
2013/07/19 面试题
超市实习总结自我鉴定
2013/09/19 职场文书
护理专业大学生自我推荐信
2014/01/25 职场文书
主持人婚宴答谢词
2014/01/28 职场文书
市场营销策划方案
2014/06/11 职场文书
教师优秀党员事迹材料
2014/08/14 职场文书
六一领导慰问欢迎词
2015/01/26 职场文书
python 实现两个变量值进行交换的n种操作
2021/06/02 Python