集合关联报错:SyntaxError: Unexpected token R in JSON at position 0
命令行报错:
SyntaxError: Unexpected token R in JSON at position 0 at JSON.parse (<anonymous>) at E:\代码练习\node\day-07\blogs\app.js:45:25 at Layer.handle_error (E:\代码练习\node\day-07\blogs\node_modules\express\lib\router\layer.js:71:5) at trim_prefix (E:\代码练习\node\day-07\blogs\node_modules\express\lib\router\index.js:315:13) at E:\代码练习\node\day-07\blogs\node_modules\express\lib\router\index.js:284:7 at Function.process_params (E:\代码练习\node\day-07\blogs\node_modules\express\lib\router\index.js:335:12) at next (E:\代码练习\node\day-07\blogs\node_modules\express\lib\router\index.js:275:10) at E:\代码练习\node\day-07\blogs\node_modules\express\lib\router\index.js:635:15 at IncomingMessage.next (E:\代码练习\node\day-07\blogs\node_modules\express\lib\router\index.js:260:14) at done (E:\代码练习\node\day-07\blogs\node_modules\express\lib\response.js:1007:25)
代码
// 查询所有文章数据
let articles = await Article.find().populate('author');
在mongoose中使用populate方法实现集合关联时,导致模板引擎art-template无法渲染,如果前面使用JSON数据类型转换就会报错:SyntaxError: Unexpected token R in JSON at position 0
解决方法一:populate方法后调用lean()方法。
// 查询所有文章数据 let articles = await Article.find().populate('author').lean();
``lean()方法:是告诉mongoose返回的是普通对象,而不是mongoose文档对象,先用过JSON.stringify()这个方法将文档对象转换为字符串,将其他的属性格式全部去掉,只需要留下需要的数据字符串即可
解决方法二
const { Article } = require('../../model/article');
const pagination = require('mongoose-sex-page');
module.exports = async(req, res) => {
//标识,表示当前访问的是文章管理页面
req.app.locals.currentLink = 'article';
// 从客户端获取page页数
const page = req.query.page;
//page() 指定当前页
//size() 每页显示几条数据
//display() 指定客户端要显示的页码数量
//查询文章数据 关联Article数据库中的 author字段,渲染作者名字
let articles = await pagination(Article).page(page).size(8).display(3).find().populate('author').exec();
let str = JSON.stringify(articles);
let json = JSON.parse(str);
// res.send(json)
res.render('admin/article.art', {
articles: json
});
}
使用stringify()方法和parse()方法,将对象转换为字符串,然后再次使用parse()方法转换为JSON格式。 注意:传递数据的时候是传递转换后的json变量。
浙公网安备 33010602011771号