跨平台应用开发进阶(四十九)由环境切换引发的页面通讯机制思考

一、前言

APP开发完毕,app store上架审核前存在后台晚于APP发布的场景,鉴于APP首页页面渲染依赖于后台接口,且苹果上架审核人员对于页面渲染效果比较苛刻,故制定出应用启动时默认连接生产环境,通过接口查询识别到非发版版本时切换到UAT环境的应对策略。

二、解决方案

uni-app实现过程中,APP.vue作为首加载文件,环境切换在此页面的onLoad方法中完成。环境切换完成后,通过页面通讯方式完成页面接口间的依赖关系制定。

APP.vue 通过触发全局的自定义事件方式,告知全局环境切换已完成。

javascript 复制代码
uni.$emit('switchRequestAddress', {msg: true});

APP首页通过监听全局的自定义事件方式,获悉全局环境切换已完成,可正常进行接口调用。

javascript 复制代码
uni.$once('switchRequestAddress', data => {
	console.log('监听到事件来自 update ,携带参数 msg 为:' + data.msg);
})

通过以上方式便可实现应用正式上架前根据生产环境信息动态切换接口请求环境效果。

感悟: 总体来看,uni-app开发过程中遇到的问题均可以在uni-app官方文档中找到相应的解决方案,所以技术文档还是要熟悉。

2.1 uni.$on(eventName,callback)uni.$once(eventName,callback) 的区别

  • uni.$on(eventName,callback):监听全局的自定义事件,事件由 uni.$emit 触发,回调函数会接收事件触发函数的传入参数。
  • uni.$once(eventName,callback):监听全局的自定义事件,事件由 uni.$emit 触发,但仅触发一次,在第一次触发之后移除该监听器。

三、拓展阅读

相关推荐
weixin1997010801611 小时前
南网商城商品详情页前端性能优化实战
java·前端·性能优化
陈天伟教授11 小时前
WEB应用安全与防护 - 实操案例 2:CSRF(跨站请求伪造)—— 伪造用户操作
前端·安全·xss
@PHARAOH11 小时前
HOW - 依赖包版本 lock 维护策略(pnpm)
前端
SuperEugene11 小时前
前端-后端-产品-项目-运维:互联网项目协作全流程解析
运维·前端·javascript
weixin1997010801611 小时前
网易考拉商品详情页前端性能优化实战
java·前端·python·性能优化
A黄俊辉A11 小时前
openlayers+vue初学注意点
前端·javascript·vue.js
南篱11 小时前
从回调地狱到优雅异步:JavaScript 异步编程的完整演进之路
前端·javascript·面试
陆枫Larry11 小时前
折叠屏“窗口化”导致的背景图错位:一次小程序样式问题的排查与修复
前端
米丘11 小时前
vue 3.x 关于 provide 与 inject 实现原理
前端
进击的雷神11 小时前
无分页一次性加载、多级CSS类名定位、动态User-Agent轮换、断点本地备份——意大利塑料展爬虫四大技术难关攻克纪实
前端·css·爬虫·python