生于理想

导航

集合关联报错: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变量。

posted on 2021-12-02 19:29  生于理想  阅读(158)  评论(0)    收藏  举报