Конвертировать документы Mongoose в JSON - PullRequest
60 голосов
/ 31 марта 2012

Я вернул документы mongoose как json следующим образом:

UserModel.find({}, function (err, users) {
    return res.end(JSON.stringify(users));
}

Однако, пользователь .__ proto__ также был возвращен.Как я могу вернуться без него?Я попробовал это, но не сработало:

UserModel.find({}, function (err, users) {
    return res.end(users.toJSON());    // has no method 'toJSON'
}

Ответы [ 8 ]

123 голосов
/ 03 января 2013

Вы также можете попробовать mongoosejs's lean () :

UserModel.find().lean().exec(function (err, users) {
    return res.end(JSON.stringify(users));
}
44 голосов
/ 01 февраля 2014

Поздний ответ, но вы также можете попробовать это при определении схемы.

/**
 * toJSON implementation
 */
schema.options.toJSON = {
    transform: function(doc, ret, options) {
        ret.id = ret._id;
        delete ret._id;
        delete ret.__v;
        return ret;
    }
};

Обратите внимание, что ret - это объект JSON, и он не является экземпляром модели mongoose.Вы будете работать с ним прямо на хешах объектов, без методов получения / установки.

А затем:

Model
    .findById(modelId)
    .exec(function (dbErr, modelDoc){
         if(dbErr) return handleErr(dbErr);

         return res.send(modelDoc.toJSON(), 200);
     });

Редактировать: февраль 2015

Поскольку я не предоставил решения для отсутствующего метода (ов) toJSON (или toObject), я объясню разницу между моим примером использования и примером использования OP.

OP:

UserModel
    .find({}) // will get all users
    .exec(function(err, users) {
        // supposing that we don't have an error
        // and we had users in our collection,
        // the users variable here is an array
        // of mongoose instances;

        // wrong usage (from OP's example)
        // return res.end(users.toJSON()); // has no method toJSON

        // correct usage
        // to apply the toJSON transformation on instances, you have to
        // iterate through the users array

        var transformedUsers = users.map(function(user) {
            return user.toJSON();
        });

        // finish the request
        res.end(transformedUsers);
    });

Мой пример:

UserModel
    .findById(someId) // will get a single user
    .exec(function(err, user) {
        // handle the error, if any
        if(err) return handleError(err);

        if(null !== user) {
            // user might be null if no user matched
            // the given id (someId)

            // the toJSON method is available here,
            // since the user variable here is a 
            // mongoose model instance
            return res.end(user.toJSON());
        }
    });
24 голосов
/ 31 марта 2012

Прежде всего, попробуйте toObject() вместо toJSON(), может быть?

Во-вторых, вам нужно вызывать его для реальных документов, а не для массива, так что, возможно, попробуйте что-нибудь более раздражающее, например:

var flatUsers = users.map(function() {
  return user.toObject();
})
return res.end(JSON.stringify(flatUsers));

Это предположение, но я надеюсь, что это поможет

12 голосов
/ 19 февраля 2014
model.find({Branch:branch},function (err, docs){
  if (err) res.send(err)

  res.send(JSON.parse(JSON.stringify(docs)))
});
6 голосов
/ 31 марта 2012

Я узнал, что сделал ошибку. Нет необходимости вызывать toObject () или toJSON () вообще. __Proto__ в вопросе пришло от jquery, а не от mongoose. Вот мой тест:

UserModel.find({}, function (err, users) {
    console.log(users.save);    // { [Function] numAsyncPres: 0 }
    var json = JSON.stringify(users);
    users = users.map(function (user) {
        return user.toObject();
    }
    console.log(user.save);    // undefined
    console.log(json == JSON.stringify(users));    // true
}

doc.toObject () удаляет doc.prototype из документа. Но это не имеет значения в JSON.stringify (doc). И это не нужно в этом случае.

2 голосов
/ 22 марта 2018

Может быть, немного в заблуждении относительно ответа, но если кто-то хочет сделать наоборот, вы можете использовать Model.hydrate() (начиная с mongoose v4), чтобы преобразовать объект javascript (JSON) в документ mongoose.

Полезный случай будет, когда вы используете Model.aggregate(...).Поскольку он на самом деле возвращает простой JS-объект, вы можете преобразовать его в документ mongoose, чтобы получить доступ к Model.method (например, вашему виртуальному свойству, определенному в схеме).

PS.Я думал, что должен быть поток, работающий как " Конвертировать json в Mongoose docs ", но на самом деле нет, и так как я нашел ответ, то я думаю, что это не очень хорошо делать после публикациии-я-ответ.

1 голос
/ 22 августа 2017

Попробуйте следующие варианты:

  UserModel.find({}, function (err, users) {
    return res.end( JSON.parse(JSON.stringify(users)) );
    //Or: 
    //return JSON.parse(JSON.stringify(users));
  }
1 голос
/ 22 сентября 2016

Вы можете использовать res.json () для jsonify любого объекта.lean () удалит все пустые поля в запросе мангусты.

UserModel.find().lean().exec(function (err, users) { return res.json(users); }

...