业务需求是,维护登录态的代码写在app.js里的,获取到登录态后保存到globaldata里,子页面的请求接口都需要携带登录态,直接拿globaldata里的登录态就可以。遇到的问题是,经常子页面比如index页面里的代码在app.js执行完毕前就执行,就拿不到globaldata里的登录态。我的思路是能不能把app.js里维护登录态的代码用Promise改写一下,然后把Promise实例放到globaldata里,子页面比如index页面取globaldata的Promise实例等待状态变为resolve时就可以拿到登录态然后再请求接口了。下面是我回调函数方式维护登录态的大体流程:请教大佬怎么改写呢?wx.getStorage({//Storage里取登录态key:'loginState',success(res){//登录态存在wx.checkSession({success(){//session_key未过期},fail(){//session_key已经失效,需要重新执行登录流程wx.login({success(val){wx.request({url:'https://test.com/onLogin',data:{code:val.code},success(data){this.globalData.uid=data.uid;//将后端返回的登录态uid保存到globalData方便子页面使用}})}})//重新登录}})},fail(){wx.login()//登录态不存在,重新登录}})
喵喵时光机
相关分类