uni-app组件之间的通讯--父子/兄弟组件之间传递数据

uni-app组件之间的通讯–父子/兄弟组件之间传递数据
e m i t 、 emit、 emiton、 o f f 常 用 于 跨 页 面 、 跨 组 件 通 讯 u n i . off常用于跨页面、跨组件通讯 uni. offuni.emit(eventName,OBJECT) 触发全局的自定事件。
uni. o n ( e v e n t N a m e , c a l l b a c k ) 监 听 全 局 的 自 定 义 事 件 。 事 件 可 以 由 u n i . on(eventName,callback) 监听全局的自定义事件。事件可以由 uni. on(eventName,callback)uni.emit 触发,回调函数会接收所有传入事件触发函数的额外参数。
uni.$off([eventName, callback]) 移除全局自定义事件监听器
一、父组件给子组件传递数据
子组件通过props接收外界传递到组件内部的值

// 父 index.vue 通过属性绑定进行传递 v-bind:简写为:


data() {
return {
title:‘Hello’,
}
},

// 子组件 test.vue 通过props接收

这是父组件传递过来的数据{{title}}

export default {
    props:['title'],//接收
}

二、子组件向父组件传值
通过$emit触发事件进行传递参数

// 子组件 test.vue 传值num


子组件点击按钮触发给父组件传值
<button @click=“sendNum”>给父组件传值

// index.vue 父组件接收num

<test :title=“title” @myEven= ‘getNum’>{{num}}

export default {
data() {
return {
num:0,//默认0
}
},
methods: {
getNum(num){
console.log(num)
     this.num = num
}
},
}

三、兄弟组件之间通讯
a.创建组件a,b,引入index.vue, components注册

// index .vue 页面展示组件内容

b.通过uni. o n 注 册 一 个 全 局 监 听 事 件 , 通 过 u n i . on注册一个全局监听事件,通过uni. onuni.emit触发全局监听事件

//a组件 a.vue

<button @click=“addNum”>修改b组件数据

//b组件 b.vue a组件更改该组件内容


数据{{num}}

  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值