对象 SequelizeInstance 被传递

object SequelizeInstance being pass

我很困惑,希望你能帮助我。我正在使用 express.js 在 node.js 中构建应用程序并为我的 ORM 续集。我用以下代码创建了一个模型:

"use strict";

module.exports = function(sequelize, DataTypes) {
  var User = sequelize.define("User", {
    username: DataTypes.STRING
  });

  return User;
};

我的路线是这样的:

router.get('/', function (req, res) {
  models.User.findAll({ }).then(function(users) {
    res.render('index', {
      title: 'Project Insight',
      users: users
    });
  });
})

我的模板使用 EJS:

<ul>
    <% for(var i=0; i<users.length; i++) {%>
      <li><%= users[i] %></li>
    <% } %>
</ul>

我在视图中得到的输出是这样的:

[object SequelizeInstance]
[object SequelizeInstance]
[object SequelizeInstance]
[object SequelizeInstance]

我希望能够从数据库中提取姓名,但我很困惑为什么会出现这样的结果。如果您需要我提供任何信息,请告诉我。我对这一切都是陌生的,我处于停滞状态。预先感谢您的所有帮助。

尝试更改 EJS 模板:

<ul>
    <% for(var i=0; i<users.length; i++) {%>
      <li><%= users[i].username %></li>
    <% } %>
</ul>

可能对其他人有帮助:

model.findAll({where}).
  .then(res => {
    return res.map(row => {
      return row.dataValues
    });
  })

这将 return 如下所示的对象列表:

[
  {
    column1: value1,
    column2: value2,
    ...
    columnN: valueN
  }
]