微信小程序onLaunch异步,首页onLoad先执行?
发布时间:2020-12-14 19:50:56 所属栏目:资源 来源:网络整理
导读:本来按照事件顺序,初始化时触发App里的onLaunch,后面再执行页面Page里的onLoad,但是在onLaunch里请求获取是否有权限,等待返回值的时候Page里的onLoad事件就已经执行了。 onLaunch: console.log('onLaunch' url: 'test.php', success: console.log('onLau
本来按照事件顺序,初始化时触发App里的onLaunch,后面再执行页面Page里的onLoad,但是在onLaunch里请求获取是否有权限,等待返回值的时候Page里的onLoad事件就已经执行了。
onLaunch: console.log('onLaunch' url: 'test.php',
success: console.log('onLaunch-request-success'
.globalData.employId = employId: ''
})
const app = albumDisabled: bindDisabled:
onLoad: console.log('onLoad' console.log('onLoad app.globalData.employId = ' +
(app.globalData.employId && app.globalData.employId != '' albumDisabled: bindDisabled:
})
控制台打印的结果是 onLoad app.globalData.employId =
onLaunch-request-success
要是能等完onLaunch请求完再执行Page的onLoad方法那该多好。?这里采用的方法是定义一个回调函数。?Page页面判断一下当前app.globalData.employId是否有值,如果没有(第一次)则定义定义一个app方法(回调函数)app.employIdCallback = employId => {...}。?App页面在请求success后判断时候有Page页面定义的回调方法,如果有就执行该方法。因为回调函数是在Page里面定义的所以方法作用域this是指向Page页面。
onLaunch: url: 'test.php',
success: .globalData.employId =
( employId: ''
})
const app =
(app.globalData.employId && app.globalData.employId != ''
app.employIdCallback = employId => (employId != ''
这样的话,就能实现想要的结果。执行顺序就是: [App] onLaunch -> [Page] onLoad -> [App] onLaunch sucess callback
感谢大家浏览到这里~~~ (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |