如果你做一个
db.MyTable.findAll({}).function(response){
console.log(response);
}
您将看到如下所示的输出(当然,这取决于您的表格的外观):
[ { dataValues:
{ id: 1,
text: 'sdf',
complete: false,
createdAt: Thu Jan 19 2017 11:55:38 GMT-0500 (Eastern Standard Time),
updatedAt: Thu Jan 19 2017 11:55:38 GMT-0500 (Eastern Standard Time) },
_previousDataValues:
{ id: 1,
text: 'sdf',
complete: false,
createdAt: Thu Jan 19 2017 11:55:38 GMT-0500 (Eastern Standard Time),
updatedAt: Thu Jan 19 2017 11:55:38 GMT-0500 (Eastern Standard Time) },
_changed: {},
'$modelOptions':
{ timestamps: true,
instanceMethods: {},
classMethods: {},
validate: {},
freezeTableName: false,
underscored: false,
underscoredAll: false,
paranoid: false,
rejectOnEmpty: false,
whereCollection: null,
schema: null,
schemaDelimiter: '',
defaultScope: {},
scopes: [],
hooks: {},
indexes: [],
name: [Object],
omitNul: false,
sequelize: [Object],
uniqueKeys: {},
hasPrimaryKeys: true },
'$options':
{ isNewRecord: false,
'$schema': null,
'$schemaDelimiter': '',
raw: true,
attributes: [Object] },
hasPrimaryKeys: true,
__eagerlyLoadedAssociations: [],
isNewRecord: false } ]
可以说,它是一个大型的复杂对象,上面有一堆元数据。
但是,如果您尝试使用以下任一方法将该大型复杂对象转换为字符串:
console.log(JSON.stringify(dbTodo));
或
res.json(dbTodo);
您将只返回实际实体(大型复杂对象的 dataValues 属性中的项)的信息。对于我的测试表,它看起来像这样:
[{
"id":1,
"text":"sdf",
"complete":false,
"createdAt":"2017-01-19T16:55:38.000Z",
"updatedAt":"2017-01-19T16:55:38.000Z"
}]
这要简单得多(正是我想要的)。
这种魔力是如何发生的?续集是否正在创建自己的 JSON.stringify() 版本并表达 res.json?
何时发生和何时不发生有什么规则?
我已经搜索了续集文档,但没有找到一个好的解释。
此行为有两种表现方式。
-
缺少的属性是不可枚举的。由设置为
enumerable: false
Object.defineProperty
定义的属性(或者干脆不为enumerable
设置提供值)是不可枚举的属性,JSON.stringify
会忽略这些属性。您可以在Object.getOwnPropertyDescriptor(obj, propName)
的输出中检查属性的enumerable
设置。 -
对象具有(或在其原型链中具有)
toJSON
方法:如果要字符串化的对象具有名为
toJSON
的属性,其值为函数,则toJSON()
方法自定义 JSON 字符串化行为:调用toJSON()
方法返回的值将被序列化,而不是序列化的对象。如果对象具有或继承了
toJSON
方法,则该方法的返回值将成为字符串化的目标。您可以检查某个对象上是否存在一个obj
只需读取obj.toJSON
的值。