0

我正在尝试向我的 keystoneevents模型添加一个类似 id 的列。我有以下

// models/Event.js
var keystone = require('keystone'),
  Types = keystone.Field.Types;

var Event = new keystone.List('Event');

Event.add({
  FB_event_id:    { type: Types.Number, required: true, initial: true },
  name:           { type: Types.Text },
  FB_event_name:  { type: Types.Text },
  description:    { type: Types.Textarea },
  start_time:     { type: Types.Datetime },
  end_time:       { type: Types.Datetime },
  is_date_only:   { type: Types.Boolean },
  location:       { type: Types.Text },
  owner_name:     { type: Types.Text },
  updated_time:   { type: Types.Datetime },
  venue_name:     { type: Types.Text }, // typically given if lat/long data isn't
  venue_city :    { type: Types.Text },
  venue_lat :     { type: Types.Number },
  venue_long :    { type: Types.Number },
  venue_state :   { type: Types.Text },
  venue_street :  { type: Types.Text },
  venue_zip :     { type: Types.Number },
  cover_photo:    { type: Types.S3File }
});

Event.register();

在管理 UI 中,虽然我看到270,385,519,824,039哪个FB_event_id更多的是数量而不是标识号。如何删除这些逗号?使用不同的 FieldType?无论如何可以访问猫鼬ObjectId字段类型吗?http://mongoosejs.com/docs/schematypes.html我认为那将是完美的。

这纯粹是一个美学问题(也许是语义问题)。id 不带逗号地存储在数据库中。

http://keystonejs.com/docs/database/#fieldtypes-number

4

1 回答 1

0

您可以通过指定format选项来控制它,在您的情况下,您希望将其设置为false完全禁用格式:

FB_event_id:    { type: Types.Number, format: false, required: true, initial: true }

(我刚刚更新了文档,特别提到您可以将此选项设置false为完全禁用格式化)

ObjectId字段类型不是您所追求的;这些被Relationship字段类型用于链接到数据库中的其他文档,并且应该只用于存储 Mongo ObjectID。任何其他值都会导致错误。

不过就个人而言,我经常将该String字段用于 ID 类型的字段,它与该字段一样有效,Number并减少了与在 Javascript 中解析数字相关的意外行为的可能性。

于 2014-10-27T16:47:15.073 回答