Oplossing
U kunt de toObject
. aanroepen methode om toegang te krijgen tot de velden. Bijvoorbeeld:
var itemObject = item.toObject();
console.log(itemObject.title); // "foo"
Waarom
Zoals je aangeeft dat de echte velden worden opgeslagen in de _doc
veld van het document .
Maar waarom console.log(item)
=> { title: "foo", content: "bar" }
?
Uit de broncode van mongoose(document.js), kunnen we vinden dat de toString
methode van Document
bel de toObject
methode. Dus console.log
zal velden 'correct' tonen. De broncode wordt hieronder getoond:
var inspect = require('util').inspect;
...
/**
* Helper for console.log
*
* @api public
*/
Document.prototype.inspect = function(options) {
var isPOJO = options &&
utils.getFunctionName(options.constructor) === 'Object';
var opts;
if (isPOJO) {
opts = options;
} else if (this.schema.options.toObject) {
opts = clone(this.schema.options.toObject);
} else {
opts = {};
}
opts.minimize = false;
opts.retainKeyOrder = true;
return this.toObject(opts);
};
/**
* Helper for console.log
*
* @api public
* @method toString
*/
Document.prototype.toString = function() {
return inspect(this.inspect());
};