javascript – 在构造函数中调用异步函数.
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了javascript – 在构造函数中调用异步函数.,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含1628字,纯文字阅读大概需要3分钟。
内容图文
![javascript – 在构造函数中调用异步函数.](/upload/InfoBanner/zyjiaocheng/735/97928c815ca647c68a24e3ced2dd46a6.jpg)
getUser是一个异步函数?如果要花更长的时间来解决?它总是会在我的其他类中返回正确的值.
class IdpServer {
constructor() {
this._settings = {
// some identity server settings.
};
this.userManager = new UserManager(this._settings);
this.getUser();
}
async getUser() {
this.user = await this.userManager.getUser();
}
isLoggedIn() {
return this.user != null && !this.user.expired;
}
}
let idpServer = new IdpServer();
export default idpServer;
// another class
// import IdpServer from '...'
class SomeOtherClass {
constructor() {
console.log(IdpServer.isLoggedIn());
}
}
解决方法:
这是与this popular question相关的问题.
代码异步后,不能以同步方式使用.如果不希望使用原始承诺,则应使用异步功能执行所有控制流程.
这里的问题是getUser提供了用户数据的承诺,而不是用户数据本身.承诺在构造函数中丢失,这是反模式.
解决该问题的一种方法是为IdpServer提供初始化承诺,而其余的API将是同步的:
class IdpServer {
constructor() {
...
this.initializationPromise = this.getUser();
}
async getUser() {
this.user = await this.userManager.getUser();
}
isLoggedIn() {
return this.user != null && !this.user.expired;
}
}
// inside async function
await IdpServer.initializationPromise;
IdpServer.isLoggedIn();
根据应用程序的工作方式,可以在应用程序初始化时处理IdpServer.initializationPromise,以保证依赖于IdpServer的所有单元在准备好之前不会被初始化.
另一种方法是使IdpServer完全异步:
class IdpServer {
constructor() {
...
this.user = this.getUser(); // a promise of user data
}
async getUser() {
return this.userManager.getUser();
}
async isLoggedIn() {
const user = await this.user;
return user != null && !user.expired;
}
}
// inside async function
await IdpServer.isLoggedIn();
预计依赖它的所有单元也将具有异步API.
内容总结
以上是互联网集市为您收集整理的javascript – 在构造函数中调用异步函数.全部内容,希望文章能够帮你解决javascript – 在构造函数中调用异步函数.所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。