浅谈小程序跨页面之间通信的几种方式
时间:2021-08-27
来源:互联网
标签:
今天PHP爱好者给大家带来浅谈小程序跨页面之间通信的几种方式分享,本篇文章给大家分享几种常见的小程序跨页面之间通信的方式,有需要的可以参考。希望对大家有所帮助。
小程序是由一个个page构成的,如果存在路由栈为[A,B]
,A->B
传值自然可以一层层传递,但是B->A
传递数据就需要额外的辅助方式,以下讨论几种常见的方式。
1、localStorage + onShow
应用场景:A->B/B->A 都可
优点:简单操作,易理解
缺点:调用到storage,有可能设置失败;且设置后是持久缓存,可能污染原逻辑,应及时删除
应用示例:
// 以A->B示例
// A 页面
Page({
onShow(){
if(wx.getStorageSync('$datas')){
console.log(wx.getStorageSync('$datas')) // 11111
}
},
})
// B 页面
Page({
someActions(){
wx.setStorageSync('$datas','11111')
},
})
2、globalData + onShow
应用场景:A->B/B->A 都可
优点:简单操作,易理解;直接操作globalData对象,相比于storage执行效率更高
缺点:设置后是小程序生命周期内都可访问,可能污染原逻辑,应及时删除
应用示例:
// 以A->B示例
// A 页面
const app = getApp();
Page({
onShow(){
if(app.globalData.$datas){
console.log(app.globalData.$datas) // 11111
}
},
})
// B 页面
const app = getApp();
Page({
someActions(){
app.globalData.$datas = '11111';
},
})
3、小程序本身提供的 EventChannel
应用场景:主要是 B->A
优点:小程序原生提供,可随时销毁
缺点:仅限制在navigateTo
中,且要求基础库版本不低于2.7.3
应用示例:
// A页面
wx.navigateTo({
url: 'B?id=1',
events: {
// 为指定事件添加一个监听器,获取被打开页面传送到当前页面的数据
acceptDataFromOpenedPage: function(data) {
console.log(data)
},
someEvent: function(data) {
console.log(data)
}
...
},
success: function(res) {
// 通过eventChannel向被打开页面传送数据
res.eventChannel.emit('acceptDataFromOpenerPage', { data: 'test' })
}
})
// B页面
Page({
onLoad: function(option){
console.log(option.query)
const eventChannel = this.getOpenerEventChannel()
eventChannel.emit('acceptDataFromOpenedPage', {data: 'test'});
eventChannel.emit('someEvent', {data: 'test'});
// 监听acceptDataFromOpenerPage事件,获取上一页面通过eventChannel传送到当前页面的数据
eventChannel.on('acceptDataFromOpenerPage', function(data) {
console.log(data)
})
}
})
4、自定义EventBus
应用场景:A->B/B->A 都可
优点:自定义实现,可扩展
缺点:对wx进行扩展自定义变量,相同eventName可能会重复绑定监听事件
EventBus: 参考这篇EventBus实现
应用示例:
// app.js
const EventBus = require('./utils/eventBus.js');
App({
onLaunch(){
// 将eventBus初始到wx上
wx['$uhomesBus'] = (function () {
if (wx['$uhomesBus']) return wx['$uhomesBus'];
return new EventBus();
})();
}
})
// A页面
Page({
someActions(){
wx.$uhomesBus.$on('$datas',(data)=>{
console.log(data); // 11111
})
},
})
// B页面
Page({
emitActions(){
wx.$uhomesBus.$emit('$datas', '11111');
},
})
5、获取页面栈实例 getCurrentPages
应用场景:主要是 B->A
优点:小程序原生提供,处理逻辑基本都在B页面
缺点:需要增加匹配页面的相应规则,且路由栈至少有两个页面存在
应用示例:
// A页面
Page({
someActions(datas){
console.log(datas); // 11111
},
})
// B页面
Page({
someActions(){
const pages = getCurrentPages();
if (pages.length < 2) return;
// 如果页面层级较多,可用循环去匹配到A页面;
// 此处仅做2个页面的示例
const prevPage = pages[pages.length - 1];
// 路由匹配到A
if (prevPage.route === 'A') {
prevPage.someActions('11111');
}
},
})
6、globalData proxy
暂时未试验这种方式,原理上可行;
相应的原理可参考Vue3的数据劫持和订阅通知相结合;
以上就是浅谈小程序跨页面之间通信的几种方式的详细内容,更多请关注php爱好者其它相关文章!
-
如何注册谷歌账号(谷歌账号注册方法) 怎么跳过手机验证 时间:2025-09-29
-
access数据库8个经典实例 时间:2025-09-29
-
mmc.exe是什么进程 mmc.exe应用程序错误的原因及解决方法 时间:2025-09-29
-
4种基本的编程命名规范介绍(匈牙利命名法、驼峰式命名法、帕斯卡命名法、下划线命名法) 时间:2025-09-29
-
Ghostscript下载、安装教程 Ghostscript命令参数详解 时间:2025-09-29
-
Linux中内存管理NUMA架构详解 时间:2025-09-29
今日更新
-
揭秘网络四大梗:爆笑名场面背后的神转折,一次看懂全网热梗来龙去脉!
阅读:18
-
四大狗贼是什么梗?揭秘网络热词背后的爆笑真相,看完秒懂!
阅读:18
-
四大虐梗是什么梗?揭秘网络最扎心四大名场面,看完泪崩!
阅读:18
-
全境封锁手游需要什么配置-全境封锁手机配置
阅读:18
-
恋与制作人2025中秋节福利情报-登录可获得中秋赠礼
阅读:18
-
燕云十六声跑图长鸣玉获得方法-快速积攒长鸣玉
阅读:18
-
第五人格第四十赛季精华1时装囚徒黎明赋格设计公布
阅读:18
-
元梦之星美团皮肤怎么获取-圆梦美团皮肤获取
阅读:18
-
华夏绘世录中秋活动金秋献瑞明日开启-参与得奖励
阅读:18
-
QQ飞车T车孙悟空有什么特性-孙悟空赛车技能
阅读:18