onLoad(async () => { if (uni.getStorageSync("WxAuthorization")) return; uni.login({ success: async (res) => { const data = await uni.$u.api.login.authLogin({ loginCode: res.code }); uni.setStorageSync("WxAuthorization", "Bearer " + data.token); uni.setStorageSync("loginStatus", data.loginStatus); }, }); getSwiperPic(); getNotice(); getTools(); }); 优化当前代码让他按顺序执行
时间: 2024-02-27 17:56:37 浏览: 233
为了让这段代码按顺序执行,我们可以将获取登录凭证和获取数据的操作放在同一个async函数中,并且使用await来等待前一个操作完成后再执行后面的操作。同时,我们需要将获取数据的三个函数也改为支持async/await的异步函数。
下面是优化后的代码:
```javascript
onLoad(async () => {
if (uni.getStorageSync("WxAuthorization")) return;
try {
const res = await uni.login();
const data = await uni.$u.api.login.authLogin({ loginCode: res.code });
uni.setStorageSync("WxAuthorization", "Bearer " + data.token);
uni.setStorageSync("loginStatus", data.loginStatus);
await getSwiperPic();
await getNotice();
await getTools();
} catch (error) {
console.error(error);
}
});
async function getSwiperPic() {
// 获取轮播图数据
}
async function getNotice() {
// 获取公告数据
}
async function getTools() {
// 获取工具数据
}
```
这样,代码就会按照顺序执行,并且在执行过程中如果出现异常也能够正确地处理。
阅读全文