Mongoose findOne返回空对象值

时间:2018-02-27 15:19:36

标签: node.js mongodb express mongoose mongodb-query

我已经成功地在mongodb罗盘中保存了一些文件。我试图通过查询一些参数来检索值。

据我所知,mongodb findOne有如下参数 query, fields(by default value: all), options and callback  但是操作的结果返回null并抛出类型错误。

这是我的代码:

router.get('/edit-page/:slug',(req,res) => {
  console.log('slug:\t' + req.params.slug);
  Pages.findOne({slug: req.params.slug},(errs, page) => {
    if(errs){
      req.flash('danger', 'page not found');
      console.error(errs);
    } else {
      console.log(page);
      res.render('admin/edit_page',{
        title: page.title,
        slug: slug,
        content: page.content,
        id: page._id
      });
    }
  });
});

在mongo指南针中复制我的数据结构:

{   
  "_id":"5a9568fa5ce418423ca8e29f",
  "title":"Home",
  "slug":"home",
  "content":"Home Page for Node CMS Cart",
  "sorting":100,
  "__v":0
}

错误抛出:

GET /admin/routes 200 8.634 ms - 3064
slug:    about-us
null
events.js:183
     throw er; // Unhandled 'error' event
     ^

TypeError: Cannot read property 'title' of null
    at Pages.findOne (E:\nodeCMSApp\routes\admin_routes.js:98:29)
    at model.Query.<anonymous> 
(E:\nodeCMSApp\node_modules\mongoose\lib\model.js:3928:16)
    at E:\nodeCMSApp\node_modules\kareem\index.js:297:21
    at E:\nodeCMSApp\node_modules\kareem\index.js:135:16
    at _combinedTickCallback (internal/process/next_tick.js:131:7)
    at process._tickCallback (internal/process/next_tick.js:180:9)
[nodemon] app crashed - waiting for file changes before starting...

我似乎不明白为什么在我的回调中,我无法获得对page.title的引用,因为未指定的默认字段是所有字段。

PS:Pages是我的模特课。

如果是这样,我该如何解决这个问题? 感谢。

2 个答案:

答案 0 :(得分:1)

  router.get('/edit-page/:slug', (req, res) => {
      Page.findOne({slug : req.params.slug}).then((page) => {
        if(!page) { //if page not exist in db
          return res.status(404).send('Page not found');
        }
        res.render('admin/edit_page', { //page  exist
          title: page.title,
          slug: page.slug,
          content: page.content,
          id: page._id
        });
      }).catch((e) => {//bad request 
        res.status(400).send(e);
      });
    });

使用此代码,它将起作用的逻辑是相同的,但是我已经使用诺言对它肯定有效的条件进行了处理。希望对您有帮助:)

答案 1 :(得分:0)

代码很好,你需要处理这个条件。

router.get('/edit-page/:slug', (req, res) => {
    console.log('slug:\t' + req.params.slug);
    Pages.findOne({
        slug: req.params.slug
    }, (errs, page) => {
        if (errs) {
            req.flash('danger', 'page not found');
            console.error(errs);
        } else {
            console.log(page);
            if (page) {
                res.render('admin/edit_page', {
                    title: page.title,
                    slug: slug,
                    content: page.content,
                    id: page._id
                });
            } else {
                res.status(400).send('Error message');
            }
        }
    });
});