繁体   English   中英

将查询结果传递到 node.js 到 html 的变量中

[英]passing the result of a query into a variable from node.js to html

我正在尝试使用 Node.js 从 MSSQL 获取一些数据,然后将数据从节点传递到我的 HTML 布局 (EJS),但我在最后一部分遇到了一些问题,这就是我想要做的做:

app.js 文件:

app.get('/', (req, res) => {
    var data = getJson(); // Function that return my data
    res.render(__dirname + '/index.ejs', {
        data: data
    }, (err, file) => {
        if (err) console.log(err);
        res.send(file);
    });
});

功能(也在同一个文件中):

function getJson(config) {
    sql.connect(config, err => {
        if (err) return err;
        var request = new sql.Request();
        request.query('select * from data', (err, json) => {
            if (err) return err;
            var result = JSON.stringify(json); // I tried to stringfy this, but doesn't work neither
            console.log(result); // This console inside of the function works!
            return result;
        });
    });
    return result;
};

然后当我加载页面时,我得到结果“未定义”。

但是如果我只通过 app.get 传递一个简单的变量,它就可以工作!:

app.get('/', (req, res) => {
    var data = 'data'; // Simple variable
    res.render(__dirname + '/index.ejs', {
        data: data // It works!!!
    }, (err, file) => {
        if (err) console.log(err);
        res.send(file);
    });
});

然后我试着做一个简单的函数,看看是否可以显示结果,确实可以!:

function getJson() {
    var data = 'data'; // It works too!!!
    return data;
};

所以我不知道我做错了什么,你们中的任何人都可以帮助我吗?

您的getJson正在执行异步操作。 这就是为什么您将回调传递给sql.connect而另一个传递给request.query

它是这样的。 当您调用getJson ,将执行sql.connect函数,并且该函数的其余部分继续运行( return result; )。 这就是为什么你得到未定义。

你在等待他们之前发送你的数据......

你应该学习什么是异步函数......

看看下面的代码:

function getJson(config) {
    return new Promise((resolve, reject) => {
    sql.connect(config, err => {
        if (err) return resolve(err);
        var request = new sql.Request();
        request.query('select * from data', (err, json) => {
            if (err) return reject(error);
            var result = JSON.stringify(json); // I tried to stringfy this, but doesn't work neither
            console.log(result); // This console inside of the function works!
            resolve(result);
        });
    });
    })
};

app.get('/', (req, res) => {
    getJson()
    .then(data => {
       res.render(__dirname + '/index.ejs', {
            data: data
        }, (err, file) => {
            if (err) console.log(err);
            res.send(file);
         });
    })
    .catch(error => { /* do something  */  });

});

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM