黑马博客实战项目中遇到的bug,过程写得很简略仅供自己复习参考,解决办法在文末加粗了,可以直接跳到文末查看
只是暂时解决了问题,但对问题的本质还没有清晰认识,希望有大佬指教。
只要加入populate()语句,就会出现错误
此处不是错误的根本,此处的错误是因为前面添加了错误处理中间件,上图是该中间件处理意外错误信息的时候出的错。临时调整下代码,输出一下中间件的err信息
得到下图
即错误:RangeError: Maximum call stack size exceeded。
报错大概意思是mongoose返回文档对象太过庞大。但我传的数据并不大,把传的数据console.log(articles)出来,再手动复制粘贴到代码中,赋值为变量也不会出错,说明应该是格式的问题而不是数据量的问题,啊这。
最后找到一个临时解决方法
先通过JSON.stringify()这个方法将文档对象转为字符串,将他的其他属性全部格式掉,只需要留下需要的数据字符串即可!
然后再通过JSON.parse()这个方法转为对象,这个方法丢失效率,只是暂时解决问题
//把articles反复横跳两次
articles = JSON.stringify(articles);
articles = JSON.parse(articles);
(另外附上article.js的全部代码)
//
const { Article } = require('../../model/article');
module.exports = async (req, res) => {
//标识当前访问的是文章管理页面
req.app.locals.currentLink = 'article';
let articles = await Article.find().populate('author');
articles = JSON.stringify(articles);
articles = JSON.parse(articles);
res.render('admin/article', {
articles: articles
});
}