Knex/Jade: 无法读取未定义的 属性 'length'

Knex/Jade: Cannot read property 'length' of undefined

尝试切换 Mongo 并放入 Postgres(换句话说,类似的代码在 Mongo 上运行良好)。在以下代码中获取 Cannot read property 'length' of undefined。我敢肯定这很简单,但我对这整个堆栈还是陌生的,所以很难将它们组合在一起。 knex 上的示例不多,所以即使文档非常好,我也很难找到要复制的示例。

我显然正在提取正确的数据,但我仍然不知道如何让 jade 显示它。

堆栈:Node/Express/Knex/Postgres/Jade

users.js

router.get('/', function(req, res, next) {
  db.select().from('users').limit(1)
    .then(function(users) {
        console.dir(users)})
    .then(function(users) {
        res.render('users', {users: users})})
    .catch(function(error) {
        console.error(error)
  })
});

users.jade

extends layout

block content
  h1 Users
  ul
    for user in users
      p 
        input(type="text", name="name", value="#{user.name}")
        input(type="text", name="admin", value="#{user.admin}")
        input(type="text", name="smsNumber", value="#{user.smsNumber}")

控制台

[ { uid: 1,
    name: 'Don',
    admin: 'true',
    smsNumber: '4077023951',
    created_at: null,
    updated_at: null } ]

浏览器位于 localhost:3000/users

C:\Users\dvande03\Personal\dailychallenge\views\users.jade:6 4| h1 Users 5| ul > 6| for user in users 7| p 8| input(type="text", name="name", value="#{user.name}") 9| input(type="text", name="admin", value="#{user.admin}") Cannot read property 'length' of undefined

TypeError: C:\Users\dvande03\Personal\dailychallenge\views\users.jade:6
    4|   h1 Users
    5|   ul
  > 6|     for user in users
    7|       p 
    8|         input(type="text", name="name", value="#{user.name}")
    9|         input(type="text", name="admin", value="#{user.admin}")

Cannot read property 'length' of undefined
    at eval (eval at <anonymous> (C:\Users\dvande03\Personal\dailychallenge\node_modules\jade\lib\index.js:218:8), <anonymous>:51:31)
    at eval (eval at <anonymous> (C:\Users\dvande03\Personal\dailychallenge\node_modules\jade\lib\index.js:218:8), <anonymous>:106:4)
    at eval (eval at <anonymous> (C:\Users\dvande03\Personal\dailychallenge\node_modules\jade\lib\index.js:218:8), <anonymous>:119:22)
    at res (C:\Users\dvande03\Personal\dailychallenge\node_modules\jade\lib\index.js:219:38)
    at Object.exports.renderFile (C:\Users\dvande03\Personal\dailychallenge\node_modules\jade\lib\index.js:380:38)
    at Object.exports.renderFile (C:\Users\dvande03\Personal\dailychallenge\node_modules\jade\lib\index.js:370:21)
    at View.exports.__express [as engine] (C:\Users\dvande03\Personal\dailychallenge\node_modules\jade\lib\index.js:417:11)
    at View.render (C:\Users\dvande03\Personal\dailychallenge\node_modules\express\lib\view.js:126:8)
    at tryRender (C:\Users\dvande03\Personal\dailychallenge\node_modules\express\lib\application.js:639:10)
    at EventEmitter.render (C:\Users\dvande03\Personal\dailychallenge\node_modules\express\lib\application.js:591:3)
    at ServerResponse.render (C:\Users\dvande03\Personal\dailychallenge\node_modules\express\lib\response.js:961:7)
    at C:\Users\dvande03\Personal\dailychallenge\routes\users.js:11:13
    at tryCatcher (C:\Users\dvande03\Personal\dailychallenge\node_modules\bluebird\js\main\util.js:24:31)
    at Promise._settlePromiseFromHandler (C:\Users\dvande03\Personal\dailychallenge\node_modules\bluebird\js\main\promise.js:454:31)
    at Promise._settlePromiseAt (C:\Users\dvande03\Personal\dailychallenge\node_modules\bluebird\js\main\promise.js:530:18)
    at Promise._settlePromises (C:\Users\dvande03\Personal\dailychallenge\node_modules\bluebird\js\main\promise.js:646:14)

res.render 应如下所示:res.render(view [, locals] [, callback]),其中 locals 是一个对象,其属性定义了视图的局部变量。 在您的情况下,这意味着将您呈现的行更改为:

res.render('users', {users: users})

您传递一个带有局部变量的对象来渲染。在 jade 文件中,当你想引用值时,你使用对象中的键。

解决了,但我不完全明白为什么。我在渲染之前注释掉了 console.dir 并且它有效。那是因为 console.dir .then 中的用户没有传递给渲染 .then 吗?

我也接受了上面的答案,因为没有它,我不可能到达这里。谢谢@tomtom.