【问题标题】:Having problems getting new Array Value after looping in NodeJS在 NodeJS 中循环后获取新数组值时遇到问题
【发布时间】:2020-01-31 09:50:48
【问题描述】:

由于我是 NodeJS 的新手,我尝试了几种方法,例如在我的函数上使用 async/await,但是当我尝试打印出数组 retrieveValues 时,它似乎总是为空。

即使尝试等待也无济于事,如果我在它推入数组时打印出retrieveValues,它会显示在控制台中,但之后不会显示。

router.post('/api/retrievefornotifications', (request, response) => {
    var requestBody = request.body;
    var responseCode;
    var teacher = requestBody.teacher;
    var notification = requestBody.notification;

    var emails = helper.findEmailAddresses(notification);

    console.log(emails);

    var retrieveValues = {
        recipients: []
    };

    async function suspended(dataElement) {
        con.query('SELECT COUNT(*) as count_value FROM school.schoolinformation WHERE email = ? AND user_status = ?', [dataElement, 1], function (err, result, fields) {
        // con.query('SELECT COUNT(*) as count_value FROM school.schoolinformation WHERE email = ? AND user_status = ?; SELECT COUNT(*) as count_value2 FROM school.registration_relationship WHERE teacher_email = ? AND student_email = ?', [dataElement, 1, teacher, dataElement], function (err, result, fields) {
            // console.log("dataElements %s", dataElement);
            if (!err) {
                // console.log("Count value 1: %s",result[0][0].count_value);
                // console.log("Count value 2: %s",result[1][0].count_value2);
                // var suspended = result[0][0].count_value;
                // var registerWithTeacher = result[1][0].count_value;

                // console.log(result);
                var suspended = result[0].count_value;
                // Does such an email exist? (0 - NOT SUSPENDED, 1 - SUSPENDED) - suspended
                // If 1 means it is a registered pair - registerWithTeacher
                // has been mentioned in notification
                // Is registered with the teacher
                if (suspended == 0) {
                    console.log("pushing %s", dataElement);
                    retrieveValues.recipients.push(dataElement);
                }
                else {
                    responseCode = 500;
                    helper.writeResponse(responseCode, response, 0);
                }
            }
            else {
                responseCode = 204;
                helper.writeResponse(responseCode, response, 0);
            }
        });
    }

    console.log(retrieveValues);
    response.end();

})

【问题讨论】:

标签: javascript node.js npm


【解决方案1】:

最后一个console.log 在推送之前运行。 您将函数作为回调传递,因此它将在操作结束后运行。 我稍微清理了你的代码并移动了console.log

router.post('/api/retrievefornotifications', (request, response) => {
var requestBody = request.body;
var responseCode;
var teacher = requestBody.teacher;
var notification = requestBody.notification;

var emails = helper.findEmailAddresses(notification);

console.log(emails);

var retrieveValues = {
    recipients: []
};

    con.query('SELECT COUNT(*) as count_value FROM school.schoolinformation WHERE email = ? AND user_status = ?', [dataElement, 1], function (err, result, fields) {
        if (!err) {
            var suspended = result[0].count_value;
            if (suspended == 0) {
                console.log("pushing %s", dataElement);
                retrieveValues.recipients.push(dataElement);
            }
            else {
                responseCode = 500;
                helper.writeResponse(responseCode, response, 0);
            }
        }
        else {
            responseCode = 204;
            helper.writeResponse(responseCode, response, 0);
        }
        console.log(retrieveValues);
        response.end();
    });

})

【讨论】:

  • 我真正想做的是使用挂起的函数多次查询并添加到retrieveValues数组列表中
  • 你使用什么库进行sql连接?您只能等待Promises。
  • 我用的是mysql
  • 这个模块不支持承诺。你可以使用其他支持它的,但我相信你可以在没有异步/等待的情况下做你想做的事。我只是不确定你想达到什么目的。
【解决方案2】:

也许你可以试试下面的代码:

router.post('/api/retrievefornotifications', (request, response) => {
    var requestBody = request.body;
    var responseCode;
    var teacher = requestBody.teacher;
    var notification = requestBody.notification;

    var emails = helper.findEmailAddresses(notification);

    console.log(emails);

    var retrieveValues = {
        recipients: []
    };

      const result = new Promise((resolve, reject) => {  con.query('SELECT COUNT(*) as count_value FROM school.schoolinformation WHERE email = ? AND user_status = ?', [dataElement, 1], function (err, result, fields) {
        // con.query('SELECT COUNT(*) as count_value FROM school.schoolinformation WHERE email = ? AND user_status = ?; SELECT COUNT(*) as count_value2 FROM school.registration_relationship WHERE teacher_email = ? AND student_email = ?', [dataElement, 1, teacher, dataElement], function (err, result, fields) {
            // console.log("dataElements %s", dataElement);
            if (!err) {
                // console.log("Count value 1: %s",result[0][0].count_value);
                // console.log("Count value 2: %s",result[1][0].count_value2);
                // var suspended = result[0][0].count_value;
                // var registerWithTeacher = result[1][0].count_value;

                // console.log(result);
                var suspended = result[0].count_value;
                // Does such an email exist? (0 - NOT SUSPENDED, 1 - SUSPENDED) - suspended
                // If 1 means it is a registered pair - registerWithTeacher
                // has been mentioned in notification
                // Is registered with the teacher
                if (suspended == 0) {
                    console.log("pushing %s", dataElement);
                    resolve(dataElement);
                }
                else {
                    responseCode = 500;
                    helper.writeResponse(responseCode, response, 0);
                }
            }
            else {
                responseCode = 204;
                helper.writeResponse(responseCode, response, 0);
            }
        });

    // do some stuff here
    console.log(await result);

    retrieveValues.recipients.push(await result);
    console.log(retrieveValues);
    response.end();

});

});

希望对你有帮助。

【讨论】:

    猜你喜欢
    • 2017-01-10
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多