- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在开展一项动态调查。他们的调查问题是从给定调查 GUID 的数据库中提取的。然后,根据从上面的查询中提取的每个问题的 QuestionGUID,从数据库中提取用于每个问题的答案。我似乎无法将问题答案值传递到我的 ejs 文件中。
我认为这与查询函数的异步性质有关,但我已经尝试了在此处找到的多种解决方案。
我的route.js
function router() {
// survey start page
surveyRouter.get('/', function(req, res){
var prms = req.query;
res.render('surveyIndex', {prms:prms})
});
surveyRouter.get('/:surveyGuid', function(req, res){
//empty array to put values in
var questionValues = [];
function storeQuestionValues(rows){
questionValues= rows[0];
// console.log(questionValues);
}
//surveyGUID hard coded into HTML link href
//gets questions to use in ejs
connection.query("CALL spGetSurveyQuestions(?);", req.params.surveyGuid, (err, rows, fields) => {
if(err) throw err;
//all questions
var questions = rows[0]
questions.forEach(function(question){
//push results of stored procedure that gets question values by question GUID into empty array
connection.query("CALL spGetSurveyQuestionValues(?);", question.QuestionGuid, (err, rows, fields) => {
storeQuestionValues(rows);
// console.log(questionValues);
});
});
res.render('test', {questions : questions, questionValues : questionValues });
});
});
return surveyRouter;
}
我的测试 ejs 文件
<%include partials/header%>
<div id="masthead" class="container">
<div class="row py-2">
<div class="col-md-12">
<h1 class=text-center> Satisfaction Survey</h1>
</div>
</div>
</div>
<form>
<div class="containter">
<div class="col-md-12">
<%questions.forEach(function(question){%>
<label><%= question.QustionSequence %>. <%= question.QuestionText %> </label></br>
<% questionValues.forEach(function(questionValue){%>
<p> <%= questionValue.AnswerText%></p>
<%});%>
<%});%>
</div>
</div>
</form>
<%include partials/footer%>
如果将 res.render() 移动到第二个查询函数中,我会收到 header 错误,但第一个问题的问题值出现在每个问题下。所以至少它会吐出一些东西。
现在我只是想从问题值查询中的每个问题下打印任何内容,并担心稍后什么值与什么问题相匹配。
最佳答案
通过抽出一些时间并想出一些更聪明的东西,我能够取得进步。
surveyRouter.get('/:surveyGuid/:questionSequence', function(req, res){
var questionSequence = req.params.questionSequence;
connection.query("CALL spGetSurveyQuestions(?);", req.params.surveyGuid, (err, results, fields) =>{
var questions = results[0];
if(questions[questionSequence - 1].QustionSequence == questionSequence){
connection.query("CALL spGetSurveyQuestionValues(?);", questions[questionSequence - 1].QuestionGuid, (err, results, fields) =>{
var questionValues = results[0];
res.render('test', {questions: questions, questionSequence: questionSequence, questionValues: questionValues});
});
}
});
});
关于MySQL 查询值不会传递到 ejs 文件。查询取决于先前查询的结果,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57792261/
我的应用将 SceneKit 内容的“页面”与图像和文本交替。当我从图像页面前进到新的 SceneKit 页面时,前一个 SceneKit 页面中的内容会短暂显示,然后被新内容替换。时髦。 我只使用一
我正在尝试处理(在 C# 中)包含一些数字数据的大型数据文件。给定一个整数数组,如何对其进行拆分/分组,以便如果下一个 n(两个或更多)是负数,则前一个 n 元素被分组。例如,在下面的数组中,应该使用
刚接触promises,研究过。所以我的代码和我的理解: sql.connect(config).then(function(connection) { return connection.req
目前我在 if (roobaf) block 中有一些代码,这取决于 foo 和 bar 是否为假。我可以在 block 内再次检查这些条件,但感觉像是不必要的代码重复。 if (foo) {
我是一名优秀的程序员,十分优秀!