javascript - Node : Pass array and display the values on html page

标签 javascript html node.js

我写了下面的代码来使用 mongoose 从 mongodb 读取值并将其存储在数组中:

app.get('/StudentQuestionsPage',function(req,res){
    var allQuestionsArray = studentQuestions.find();
    var questions = [];
    allQuestionsArray.exec(function(err,questions){
        if(err)
            return cosole.log(err);
        questions.forEach(function(question){       
            var elem = new Object();
            elem["id"] = question.id;
            elem["quesStatement"] = question.quesStatement;
            elem["optionA"]=question.optionA;
            elem["optionB"]=question.optionB;
            elem["optionC"]=question.optionC;
            elem["optionD"]=question.optionD;

            questions.push(elem);
            console.log(elem)
        });
    }); 
    res.render(__dirname + '/StudentQuestionsPage.html',{questions:questions});
});

我必须将这一系列问题传递到一个 html 文件,然后我必须在 HTML 上显示内容。

我写了下面的代码来在 HTML 上显示数组值,但它没有显示任何内容。 “console.log(elem)”可以在控制台上打印值。

<html>
    <head>
        <title>Online Examination Portal</title>
        <h1>Questions</h1>
    </head> 
    <body>
        <div>   
        <form>
            <h2>Questions</h2>
                <ul>
                    <% questions.forEach(function(question) { %>
                    <li>Number: <%= question.id %> <br/> Text: <%= question.quesStatement %></li>
                    <% }); %>
                </ul>
        </form>
        </div>
    </body>
</html>

请告诉我如何从 nodejs 传递值并检索并在 html 上显示它。

最佳答案

首先,将您的 questions 数组重命名为 allQuestions 或除 questions 之外的任何名称。您的 .exec 的 成功函数的参数名称与数组相同。因此,它将覆盖数组变量。 由于 allQuestionsArray.exec 是一个 async 函数,您应该从 success 函数传递 allQuestions 数组。重写你的代码如下...

app.get('/StudentQuestionsPage',function(req,res){
var allQuestionsArray = studentQuestions.find();
var allQuestions = [];
allQuestionsArray.exec(function(err,questions){
    if(err)
        return console.log(err);
    questions.forEach(function(question){       
        var elem = new Object();
        elem["id"] = question.id;
        elem["quesStatement"] = question.quesStatement;
        elem["optionA"]=question.optionA;
        elem["optionB"]=question.optionB;
        elem["optionC"]=question.optionC;
        elem["optionD"]=question.optionD;

        allQuestions.push(elem);
        console.log(elem)
    });
    res.render(__dirname + '/StudentQuestionsPage.html',{questions:allQuestions});
  }); 
});

关于javascript - Node : Pass array and display the values on html page,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34611052/

相关文章:

javascript - Angular .js : Error: [$injector:unpr] Unknown provider

javascript - 正则表达式: ignore html tags

mysql - ORM 使用什么?

javascript - Node.js 如何将脚本加载到内存中?

node.js - 在特定时间插入mongodb文档

javascript - 将变量传递给函数中的 if 语句

javascript - 如何获取JSON字符串的一部分?

html - :hover cant get third menu level to display in IE6

android - Android 上的 HTML 5 视频 : mp4 problems

背景图像顶部的 CSS 边框(相同的 div?)