mysql - ejs 模板引擎与 Express 4、对象的 foreach 函数不起作用

标签 mysql node.js express ejs embedded-javascript

我使用 ejs 1.0 和express 4,但我在迭代方面遇到问题。我尝试将 forEach 用于从数据库(mysql)返回的对象。这是我的 express 代码:

var express = require('express');
var app = express();
var bodyParser = require('body-parser');
var mysql = require('mysql');
var path = require('path');
var db = require('./config/db.js');

app.use(bodyParser.json());
app.use(bodyParser.urlencoded({ extended: true }));

app.set('view engine', 'ejs');
app.set('views', __dirname + '/views');
app.use(express.static(path.join(__dirname, 'src')));

var router = express.Router();

router.route('/todo')
    .post(function(req, res, next){
        db.query('INSERT INTO task SET todo_title = ?, todo_description =?',[req.body.title, req.body.description], function(err, info){
            if(err) {
                console.log('db error', err);
            }
            console.log('zadanie dodano z id: ');
            res.redirect('/api/todo');
        });

    }).get(function(req, res, next){
        db.query('SELECT todo_id, todo_description, data FROM task', function(err, result){
        if(err) throw err;
        var data = JSON.stringify(result);
        res.render('pages/index', {items: data});
        });
    });

router.route('todo/:todo_id')
    .get(function(req, res){

    }).post(function(req, res){

    }).delete(function(req, res){
    });

app.use('/api', router);
app.listen(3000);

和模板:

<!DOCTYPE html>
<html>
<head>
    <% include ../partials/header %>
</head>
<body class="container">
    <section id="main">
        <h1>Welcome!</h1>
        <ul>
            <% items.forEach(function(item) { %>
                <li><% item.todo_id %></li>
            <% }); %>
        </ul>
        <form action="/api/todo" method="POST">
            <label for="title">Nazwa zadania</lablel><br>
            <input name="title" type="text"><br>
            <label for="description">Opis zadania</label><br>
            <textarea name="description"></textarea><br>
            <button>Wyślij</button>
        </form>
    </section>
    <footer>
        <% include ../partials/footer %>
    </footer>
</body>
</html>

我也尝试了 for() 但它不起作用。我的对象从获取路线返回:

[{"todo_id":1,"todo_description":"cos2","data":"2014-10-22T13:02:53.000Z"},{"todo_id":2,"todo_description":"cos2","data":"2014-10-22T13:03:13.000Z"},{"todo_id":3,"todo_description":"cos2","data":"2014-10-22T13:05:00.000Z"},{"todo_id":4,"todo_description":"cos2","data":"2014-10-22T13:06:03.000Z"},{"todo_id":5,"todo_description":"cos2","data":"2014-10-22T13:13:31.000Z"},{"todo_id":6,"todo_description":"asd","data":"2014-10-22T13:15:39.000Z"}]

最佳答案

该问题可能与使用 stringify() 有关:

db.query('SELECT todo_id, todo_description, data FROM task', function(err, result){
    // ...
    var data = JSON.stringify(result);
    res.render('pages/index', {items: data});
});

stringify() 创建的字符串值没有 .forEach() 方法。而且,res.render() 和 EJS 不要求值采用 JSON 编码。

您可以将 result(ObjectArray)分配给 items,而无需涉及 JSON:

res.render('pages/index', { items: result });
<小时/>

或者,您需要在 View 中parse()它:

<% JSON.parse(items).forEach(function(item) { %>

关于mysql - ejs 模板引擎与 Express 4、对象的 foreach 函数不起作用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/26530338/

相关文章:

php - 如何在PHP中动态创建具有多个字段的表

javascript - Node 中的动态函数调用(无框架)

node.js - 如何 $match MongoDB Mongoose 查询的多个值

javascript - 如何在 ExpressJS 中使用同一路径下的第二个路由文件

php - 带有 mysql 表字段的 Mysql DATE_ADD INTERVAL

php - 根据数据库中的值自动检查复选框

node.js - react 和表达应用程序不允许jsx

node.js - 两个回调可以同时(并行)执行代码吗?

mysql - 作为多个复合 FK 约束一部分的一列是否有效且良好的设计决策?

node.js - intellij idea 中的多个 ECMA-Script 版本