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

一、前言

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 触发,但仅触发一次,在第一次触发之后移除该监听器。

三、拓展阅读

相关推荐
JYeontu几秒前
实现一个超萌的柯基交互输入框
前端
天蓝色的鱼鱼9 分钟前
Vite 8:从“混动”到“纯电”,构建性能提升10倍+
前端·vite
dreams_dream9 分钟前
XSS类型
前端·xss
wuhen_n10 分钟前
副作用的概念与effect基础:Vue3响应式系统的核心
前端·javascript·vue.js
张3蜂10 分钟前
Vue.js-知识体系
前端·javascript·vue.js
Cache技术分享11 分钟前
333. Java Stream API - 按年份找出合作最多的作者对:避免 Optional.orElseThrow() 的风险
前端·后端
用户6000718191015 分钟前
【翻译】元素与 Children 属性
前端·react.js
Mintopia17 分钟前
又快又好的前端界面软件是怎么做出来的
前端
青青家的小灰灰18 分钟前
深入解析 React 中的 useEffect:副作用管理的艺术与科学
前端·react.js
wuhen_n19 分钟前
effect函数的完整实现与追踪:深入Vue3响应式核心
前端·javascript·vue.js