极乐门资源网 Design By www.ioogu.com
uni.$emit(eventName,OBJECT)
- 触发全局的自定事件。附加参数都会传给监听器回调。
- 其中eventName为事件名,OBJECT为触发事件附加参数
示例代码如下:
uni.$emit('update',{msg:'页面更新'})
uni.$on(eventName,callback)
- 监听全局自定义事件,事件由uni.$emit()触发,回调函数会接收所有传入的数。
- eventName为事件名,callback为事件的回调函数。
示例代码如下:
uni.$on('update',function(data){ console.log('监听到事件来自 update ,携带参数 msg 为:' + data.msg); })
作用
实际开发中对于触发页面的动态更新将非常有效。
例如移动端项目通过自己编写的组件替代tabbar进行tabar跳转,恰逢这时某个页面如微信支付成功,需要返回这个tabbar页面,你会发现他不会像普通uni页面(onshow生命周期)一样会动态刷新,这就很影响用户实际体验。因此这个方法就很有效,只需要在组件中写入uni.emit(update.masq:'页面刷新')
然后在页面使用uni.on('update',function(data){ console.log('监听到事件来自 update ,携带参数 msg 为:' + data.msg); })
接收,将函数写入即可。实际应用例子如下:
组件中:
onShow() { switch (this.Tab){ case 'demo': uni.$emit('update',{msg:'页面更新'}); break; } },
demo页面中:
created() { uni.$on('update', (res) => { this.list() console.log(res, '更新'); }) },
测试最终结果:
针对于页面传参请直接使用Vue的全局变量更方便 ,因为uni-app框架的uni.$emit()和$on() 虽然使用了定时器能接收到参数,但是不知道为什么第一次总是接收不到导致很多为!后续有时间在慢慢研究为什么?但是使用Vue的全局变量能搞定一切!
如何使用uni.$emit()和uni.$on() 进行页面间通讯【有一个坑务必注意】
参考官方文档,然后记住一句话:
必须先跳转打开页面,才能发射参数,否则发射无效,接收页面无法接收
其次,如果遇到一次接收无效可能需要发送的时候增加一个定时器,不然接收$on的回调函数可能不执行
参考官方文档:https://ask.dcloud.net.cn/article/36010
<template> <view> <button @tap="click"> 点击发射 </button> </view> </template> <script> import Vue from "vue"; export default { methods: { click() { // 【非常重要】必须先跳转打开页面,才能发射参数,否则发射无效,接收页面无法接收 Vue.prototype.$uniReLaunch("/pages/test/test001"); uni.$emit("test", { test: "成功", }); console.log("发射事件test成功"); }, }, }; </script>
<template> <view></view> </template> <script> export default { onLoad() { uni.$on("test", (data) => { console.log("接收事件test成功,data=", data); }); }, }; </script>
极乐门资源网 Design By www.ioogu.com
极乐门资源网
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件!
如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
极乐门资源网 Design By www.ioogu.com
暂无uni-app如何页面传参数的几种方法总结的评论...
更新日志
2024年11月18日
2024年11月18日
- 周华健.2015-水浒三部曲原创音乐选辑【滚石】【FLAC分轨】
- 钟志刚《为爱而歌DSD》[WAV+CUE]
- 孙露《情人的眼泪》[低速原抓WAV+CUE]
- 【雨果唱片】刘明源《胡琴专辑》1993[WAV+CUE]
- 黄莺莺《25周年纪念金曲专辑》[WAV+CUE][1.1G]
- 刘德丽《刘德丽新曲+精选》2023[WAV+CUE][1G]
- 潘美辰《鹰与月》双语专辑[WAV+CUE][1G]
- 梁咏琪.2007-女色新曲+精选2CD【华纳】【WAV+CUE】
- 黎亚.2006-我不在巴黎【星外星】【FLAC分轨】
- 陈洁仪.1994-心痛【立得唱片】【WAV+CUE】
- 车载必备专用超级选曲《劲爆中文DJ》2CD[WAV+CUE]
- 群星《民歌流淌60年(黑胶CD)》2CD[WAV+分轨]
- 群星《美丽时光》紫银合金AQCD[WAV+CUE]
- 群星《12大巨星畅销精选集》[WAV分轨][1.1G]
- 华语排行冠军曲《百事音乐风云榜》[WAV+CUE][1G]