Javascript如何在扩展错误中等待 promise

标签 javascript node.js constructor async-await extends

我目前正在尝试扩展 javascript 的标准错误类以解决流程问题,更准确地说,我想在抛出自定义错误时检查 FTP 数据。问题是它在抛出之前从不等待等待函数完成。等待的函数也返回一个 promise 。

就我而言,我的类(class)有这个示例代码,请注意,remoteFs 只是一个自定义模块,其中包含我操作远程 FTP 数据的函数。

module.exports = class processError extends Error {

    constructor(args) {
        super(args);

        this.name = "customError"
        this._folder = "./test/"
        this._credentials = {
                host: 'my.host.com',
                user: 'username',
                password: 'passwd123',
            }

        return (this._errorProcess());
    }

    async _errorProcess () {

        try {
            // The function below is basic FTP list and should return a promised true/false if the folder exists or not.
            let IsThereFolder = await remoteFs.EntityExist(this._credentials, this._folder)
        } catch (err) {
            throw new Error("Fatal error in error handler:", err)
        }

        console.log("Should I create folder ?", IsThereFolder )
        return (this);
    }
}

我尝试了几种方法来让构造函数等待,例如从 init() 函数调用 _errorProcess,该函数在从构造函数调用后会返回它。我也尝试将此函数放在类范围之外,但似乎没有任何东西可以正常工作,我总是在收到我的 promise 之前得到抛出输出。

module.exports = {

EntityExist: function (credentials, toFind) {
       var c = new Client();
       let entityExist = false;

       return new Promise((resolve, reject) => {
           console.log("CREDENTIALS ->", credentials)
           c.on('ready', function () {
               console.log("Connection established");
               c.on('error', function (err) {
                   console.log(err);
                   reject(err);
               })
               c.list(toFind, (err, list) => {
                   if (err) throw err;

                   for (let i = 0; i < list.length; i++) {
                       if (list[i].name == toFind) { entityExist = true; }
                   }
                   c.on('end', () => { resolve(entityExist); })
                   c.end();
               });
           });
           console.log("Before connect")
           c.connect(credentials);
       })
   }
};

这是我这次执行得到的实际输出:

CREDENTIALS -> { host: 'my.host.com',                                                       
  user: 'username',                                                                                    
  password: 'passwd123' }                                                                                  
Before connect                                                                                          

C:\path_to_project\includes\file.js:62 
                        throw new handleError("Testing custom error: " + err); break;    
                        ^                                                                               
[object Promise]

npm ERR! code ELIFECYCLE
npm ERR! errno 1
(...)

因此,正如您所看到的,它不会等待 promise 返回,甚至不会到达 EntityExist 函数上的“已建立连接”日志(请注意,该函数在其他情况下工作正常)。

实际上,我什至不知道是否可以直接从构造函数执行此类操作。 我希望上下文足够清楚,谢谢您的时间!

最佳答案

The await operator is used to wait for a Promise. It can only be used inside an async function.

这意味着您不能在全局范围或类构造函数中使用。

使用 Promise 的构造函数是一种不好的做法,因为您也无法获取该类 (link to another stackoverflow answer) .

从技术上讲,您可以从构造函数返回 Promise,但这不是他的目的。

根据您的情况,您可以在调用 throw 之前使用一个函数,这并不美观,但它可以完成工作。

如:

async generateAsyncError(asyncFn) {
  await asyncFn();

  throw new Error();
}

这里你可以在抛出错误之前使用 async。但请记住,在异步函数完成之前,不会抛出错误。

关于Javascript如何在扩展错误中等待 promise ,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58379120/

相关文章:

node.js - Parse.com Node js 无法加载 json 文件

javascript - 简单的javascript游戏: Object creation error due to constructor or conditional operators

c++ - 从另一个类的构造函数将数组传递给类函数

javascript - 类型 '(isOpen: boolean) => void' 不可分配给类型 'boolean' 。在reactjs中使用Modal时出错

javascript - Instagram JSON 响应重定向到登录 [Discord JS 和 Heroku]

node.js - Nodejs 并行编程使用线程

c# - 参数可选时如何获取默认构造函数

javascript - JSON.stringify (Javascript) 和 json.dumps (Python) 不等价吗?

javascript - 阻止 js 函数在已经执行时执行

javascript - 将遍历所有 css 文件并将每个 .classname 更改为 .class-name 的脚本