[英]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.