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 相关文章推荐
Display SQL Server Login Mode
Jun 21 Javascript
javascript 面向对象编程基础:封装
Aug 21 Javascript
JavaScript 定义function的三种方式小结
Oct 16 Javascript
silverlight线程与基于事件驱动javascript引擎(实现轨迹回放功能)
Aug 09 Javascript
js获取图片大小的函数代码
Sep 20 Javascript
JavaScript字符串对象toLowerCase方法入门实例(用于把字母转换为小写)
Oct 17 Javascript
javascript+canvas实现刮刮卡抽奖效果
Jul 29 Javascript
JS中的forEach、$.each、map方法推荐
Apr 05 Javascript
JS不用正则验证输入的字符串是否为空(包含空格)的实现代码
Jun 14 Javascript
Angular 2父子组件数据传递之@ViewChild获取子组件详解
Jul 04 Javascript
vue子组件改变父组件传递的prop值通过sync实现数据双向绑定(DEMO)
Feb 01 Javascript
原生JS实现拖拽功能
Dec 16 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环境套包 dedeampz 伪静态设置示例
2014/03/26 PHP
PHP中使用localhost连接Mysql不成功的解决方法
2014/08/20 PHP
php打造智能化的柱状图程序,用于报表等
2015/06/19 PHP
PHP cookie与session会话基本用法实例分析
2019/11/18 PHP
AutoSave/自动存储功能实现
2007/03/24 Javascript
JQuery 初体验(建议学习jquery)
2009/04/25 Javascript
Javascript remove 自定义数组删除方法
2009/10/20 Javascript
JavaScript 组件之旅(一)分析和设计
2009/10/28 Javascript
自定义刻度jQuery进度条及插件
2015/09/02 Javascript
浅析jQuery中使用$所引发的问题
2016/05/29 Javascript
js事件驱动机制 浏览器兼容处理方法
2016/07/23 Javascript
javascript简单实现跟随滚动条漂浮的返回顶部按钮效果
2016/08/19 Javascript
Html中 IFrame的用法及注意点
2016/12/22 Javascript
VUE使用vuex解决模块间传值问题的方法
2017/06/01 Javascript
Vue实现调节窗口大小时触发事件动态调节更新组件尺寸的方法
2018/09/15 Javascript
validform表单验证的实现方法
2019/03/08 Javascript
使用 js 简单的实现 bind、call 、aplly代码实例
2019/09/07 Javascript
移动端JS实现拖拽两种方法解析
2020/10/12 Javascript
Python 爬虫学习笔记之单线程爬虫
2016/09/21 Python
Python tkinter事件高级用法实例
2018/01/31 Python
pygame游戏之旅 添加键盘按键的方法
2018/11/20 Python
python 定时任务去检测服务器端口是否通的实例
2019/01/26 Python
Pycharm远程调试原理及具体配置详解
2019/08/08 Python
使用python os模块复制文件到指定文件夹的方法
2019/08/22 Python
CSS3 实现弹跳的小球动画
2020/10/26 HTML / CSS
英国探险旅游专家:Explore
2018/12/20 全球购物
可爱的童装和鞋子:Fabkids
2019/08/16 全球购物
UNIX文件系统分类
2014/11/11 面试题
出国考察邀请函
2014/01/21 职场文书
2014小学一年级班主任工作总结
2014/12/05 职场文书
退税申请报告怎么写
2015/05/18 职场文书
手术室消毒隔离制度
2015/08/05 职场文书
Python基础详解之邮件处理
2021/04/28 Python
vue-cli4.5.x快速搭建项目
2021/05/30 Vue.js
idea以任意顺序debug多线程程序的具体用法
2021/08/30 Java/Android
Win11安装升级时提示“该电脑必须支持安全启动”
2022/04/19 数码科技