3

我使用 mongoose.js 将一些数据集保存到 MongoDB。但是我在使用 express.js 和 ejs 的 html 网站上显示它们时遇到了问题。

这是我的场景:

模型

var mongoose = require('mongoose');

var Schema = mongoose.Schema;
var ObjectId = Schema.ObjectId;

var ItemSchema = new Schema({
    _id: ObjectId,
    creationTime: Date,
    modificationTime: Date,
    title: String
});
var Item = mongoose.model('item', ItemSchema);
module.exports.Item = Item;

路线:

app.get('/item/:id', function(req, res) {

    Item.findById(req.params.id, function(err, doc){

        console.log(doc); //This check displays everything correctly on console

        res.render('item.html.ejs', {
            item : doc
        });
    });
});

看法:

<h1><%= item.title %>:</h1>
<p>Creation: <%= item.creationDate %></p>
<p>Modification: <%= item.modificationDate %></p>

此设置的结果是标题正确显示,而两个日期均为undefined.

我认为这与 MongoDB 的 ISODate 格式有关。但我找不到如何将其转换为在 html 视图中显示的解决方案。

我感谢您的帮助。干杯

4

3 回答 3

9

我的项目中有以下使用 moment.js 的助手。

date: function(date){
  moment(date).format('YYYY-MM-DD hh:mm:ss');
},
fromNow: function(date){
  moment(date).fromNow()
}
于 2012-06-04T09:43:14.170 回答
1

如果您只是复制并粘贴代码,则解决方案非常简单。

在您的模型中,您在模板中定义了创建Time和修改Time,您尝试访问 item.creationDate和 item.modification Date

更改之后,您应该能够看到其他未定义的内容,但您可能仍需要将其转换为正确的日期格式。

于 2012-06-04T14:20:36.773 回答
1

我使用上面的示例添加了一个 ejs 过滤器,但我必须对其进行一些更改才能使其正常工作:

在 mongoose 模式上创建 'created_at' 属性并在 save() 上自动创建它:

var ItemSchema = new Schema({
    name    : { type: String, required: true, trim: true }
  , created_at    : { type: Date }
});


ItemSchema.pre('save', function(next){
  if ( !this.created_at ) {
    this.created_at = new Date;
  }
  next();
});

安装时刻(并写入 package.json)

npm install moment --save

在 app.js 或您为 ejs 定义过滤器的任何其他位置添加过滤器:

var moment = require('moment');

ejs.filters.fromNow = function(date){
  return moment(date).fromNow()
}

在 page.ejs 中使用过滤器

<span class="created_at"><%=: item.created_at | fromNow %></span>
于 2012-10-01T09:02:54.137 回答