(1)props属性:
在父组件中,可以通过子组件标签属性的形式将数据或者函数传给子组件,子组件通过props去读取父组件传过来的数据
用法
父组件传数据给子组件:
- 一般的属性值都是用来给子组件展示的
子组件传数据给父组件
- 属性值为函数类型的,一般是用来子组件向父组件传递数据,子组件通过调用父组件传过来的函数,可以修改父组件的状态数据
缺点:
- 隔层组件间传递: 必须逐层传递(麻烦)
- 兄弟组件间: 必须借助父组件(麻烦)
注意:
//子组件获取父组件传过来的值 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组件之间的数据传递方法详解整合,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对网站的支持!
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
更新日志
- 凤飞飞《我们的主题曲》飞跃制作[正版原抓WAV+CUE]
- 刘嘉亮《亮情歌2》[WAV+CUE][1G]
- 红馆40·谭咏麟《歌者恋歌浓情30年演唱会》3CD[低速原抓WAV+CUE][1.8G]
- 刘纬武《睡眠宝宝竖琴童谣 吉卜力工作室 白噪音安抚》[320K/MP3][193.25MB]
- 【轻音乐】曼托凡尼乐团《精选辑》2CD.1998[FLAC+CUE整轨]
- 邝美云《心中有爱》1989年香港DMIJP版1MTO东芝首版[WAV+CUE]
- 群星《情叹-发烧女声DSD》天籁女声发烧碟[WAV+CUE]
- 刘纬武《睡眠宝宝竖琴童谣 吉卜力工作室 白噪音安抚》[FLAC/分轨][748.03MB]
- 理想混蛋《Origin Sessions》[320K/MP3][37.47MB]
- 公馆青少年《我其实一点都不酷》[320K/MP3][78.78MB]
- 群星《情叹-发烧男声DSD》最值得珍藏的完美男声[WAV+CUE]
- 群星《国韵飘香·贵妃醉酒HQCD黑胶王》2CD[WAV]
- 卫兰《DAUGHTER》【低速原抓WAV+CUE】
- 公馆青少年《我其实一点都不酷》[FLAC/分轨][398.22MB]
- ZWEI《迟暮的花 (Explicit)》[320K/MP3][57.16MB]