UniApp 微信小程序:在 onLaunch 中等待异步方法执行完成后,再调用页面中的接口

最近遇到了一个问题:在 App.vue 中的 onLaunch 中调用登录接口时,由于异步登录尚未完成就调用了 index 页面的接口,导致 token 异常。如何确保页面在 App 中的 onLaunch 执行完毕后再继续执行呢? 在网上查阅了一些资料,发现大多数解决方案涉及登录状态设置、页面通过轮询或消息通知等方式等待状态,这些方法都不太理想。

解决方案:

要确保在App.vue中的onLaunch调用登录接口完成后再调用index的其他接口,可以使用 Promise 来控制异步操作的执行顺序

1、在App.vue中,使用Promise封装登录接口的调用,并在登录成功后返回一个resolve。

javascript 复制代码
export default {
  onLaunch() {
    // 封装登录接口为一个Promise
    const loginPromise = new Promise((resolve, reject) => {
      // 调用登录接口
      loginFunction().then(() => {
        // 登录成功时,执行 resolve
        resolve();
      }).catch((error) => {
        // 登录失败时,执行 reject
        reject(error);
      });
    });

    // 将 loginPromise 作为一个全局变量
    this.globalData.loginPromise = loginPromise; 
  }
}

2、在index页面中,在页面加载时,通过调用登录接口的Promise,等待登录接口成功后再调用其他接口。

javascript 复制代码
export default {
  onLoad() {
    // 获取 App 实例
    const appInstance = getApp();

    // 等待登录接口的Promise完成后,再调用其他接口
    appInstance.globalData.loginPromise.then(() => {
      // 调用 index 页面的接口
      getIndexInfo().then((res) => {
        // 处理其他接口的结果
      }).catch((error) => {
        // 错误处理
      });
    }).catch((error) => {
      // 登录失败处理
    });
  }
}

测试通过完工 ~

可能有同学会有疑问,每次获取loginPromise的时候会不会每次都登录?

答案是不会的,App.vue 中的 loginPromise 是在 onLaunch 生命周期钩子中创建的 Promise 对象,该 Promise 对象只会在应用初始化时调用一次登录接口,并在登录成功后 resolve。之后,其他页面获取 loginPromise 时并不会触发再次登录,而是直接返回之前创建好的 Promise 对象。

这意味着,每次获取 loginPromise 时不会导致重复登录,而是仅返回之前创建好的 Promise 对象。这种方式确保了登录操作只会在应用启动时执行一次,避免了重复登录

相关推荐
一点晖光4 小时前
微信小程序输入框光标从中间删除跳到最后bug解决
微信小程序·uniapp·ios光标
济南壹软网络科技有限公司4 小时前
国际盲盒电商新范式:深度剖析 V4 系统的全球化云原生架构
uni-app·盲盒源码·国际盲盒源码·盲盒开源源码·多语言盲盒源码
小皮虾4 小时前
护航隐私!小程序纯前端“证件加水印”:OffscreenCanvas 全屏平铺实战
前端·javascript·微信小程序
白宇横流学长5 小时前
基于SpringBoot医院复查开药网站和微信小程序的设计
spring boot·后端·微信小程序
项目題供诗8 小时前
微信小程序黑马优购(项目)(七)
微信小程序·小程序
2501_915918418 小时前
HTTPS 端口深度解析,443 并不是唯一入口,理解 TLS 流量行为与抓包策略
网络协议·http·ios·小程序·https·uni-app·iphone
2501_916008899 小时前
iOS 开发者工具全景图,构建从编码、调试到性能诊断的多层级工程化工具体系
android·ios·小程序·https·uni-app·iphone·webview
走,带你去玩9 小时前
uniapp live-pusher + 腾讯云直播
前端·javascript·uni-app
qq_12498707539 小时前
基于微信小程序的家电维修平台的设计与实现(源码+论文+部署+安装)
微信小程序·小程序·毕业设计
2501_9159214310 小时前
从需求到上架,现代 iOS 开发流程的工程化方法论
android·ios·小程序·https·uni-app·iphone·webview