1

您好,提前谢谢您。我正在使用 npm 乏味的包与数据库进行交互。我也在使用 Meteor.call 和方法,为此我需要传递一个变量(在下面的示例中为 newdata),该变量携带从数据库中获取的数据作为函数“rr”的返回值,这样我就可以能够通过 Meteor 调用在客户端使用函数的结果。

 function rr(){
        var newdata = [];

        var ahora = new Request("SELECT * FROM prueba", function (err) {
                if (err) {
                    console.log("err1");
                } else {
                }
            })
            ahora.on('row', function(columns) {
                columns.forEach(function(column) {
                    newdata.push(column.value);
                       });
                });
}

我希望“newdata”成为 rr 函数的结果。我怎样才能做到这一点?如果我写“返回新数据”它是未定义的,我不能使用等待,因为新数据不是任何函数的返回值......

非常感谢。

4

2 回答 2

2

你可以这样做:

function rr(){
    return await new Promise((resolve, reject) => {
               new Request("SELECT * FROM prueba", (err, rowCount) => {err && reject(err);})
                      .on('row', columns => resolve(columns.map(c => c.value)));
    });
}
于 2018-01-13T17:48:14.863 回答
1

Tedious 似乎本身并不支持 Promise,但您可以将函数包装在 Promise 中:

function rr() {
    return new Promise((resolve, reject) => {
        var ahora = new Request("SELECT * FROM prueba", function (err) {
            if (err) {
                reject(err);
            }
        });
        var newdata = [];
        ahora.on('row', function(columns) {
            columns.forEach(function(column) {
                newdata.push(column.value);
            });
        });
        resolve(newdata);
    }
}

或略短:

function rr() {
    return new Promise((resolve, reject) => {
        new Request("SELECT * FROM prueba")
            .on("error", reject)
            .on("row", function(columns) {
                resolve(columns.map(column => column.value))
            });
    }
}

如果您不想手动做出承诺,可以尝试 Bluebird 的promisify 功能。我还发现了一个乏味的特定承诺包 tedious -promises,但它似乎没有得到适当的维护。

于 2018-01-13T17:48:54.593 回答