Løsning
Du kan kalde toObject
metode for at få adgang til felterne. For eksempel:
var itemObject = item.toObject();
console.log(itemObject.title); // "foo"
Hvorfor
Som du påpeger, at de rigtige felter er gemt i _doc
felt i dokumentet .
Men hvorfor console.log(item)
=> { title: "foo", content: "bar" }
?
Fra kildekoden til mongoose(document.js) kan vi finde ud af, at toString
metode til Document
kald toObject
metode. Så console.log
vil vise felter 'korrekt'. Kildekoden er vist nedenfor:
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());
};