Bootstrap

跳转传参报错:SyntaxError: Unexpected end of JSON input

小程序里面 SyntaxError: Unexpected end of JSON input报错怎么解决


问题背景
小程序,经常有跳转传参的功能,一般带一个id或者name,title之类很短的字段,但是如果带很多数据的话,很多人喜欢使用json转换,传一个对象过去小程序传参但这样仅限于很少的字段,不然就会出现错误,如下图

产生原因
这是因为navigateTo方法携带的参数是有字符串长度限制的,超出部分就无法携带了,这就回导致传递过去的对象不闭合,使用json解析的时候就产生了报错.

解决方法
1、如果业务场景是从列表页面跳转到详情页面,那么推荐只携带少量字段,如id,然后在详情页面使用id请求详情,这样就不用烦心字符长度超出的问题了.(强烈推荐)

2、如果不想请求新的数据,就用列表本身的字段,但是字符串超出的话,可以考虑下面方法.
使用decodeURIComponent 和encodeURIComponent 函数进行操作.

列表页面代码:

  toDetail(e) {
    const item = e.currentTarget.dataset.item
    console.log('需要传递的参数', item)
    wx.navigateTo({
      url: '/pagesA/paramsDetail/paramsDetail?item=' + encodeURIComponent(JSON.stringify(item))
    })
  }

详情页面代码:

  onLoad: function (options) {
    const {
      item
    } = options
    console.log('item', item)
    const detail = JSON.parse(decodeURIComponent(item))
    console.log('detail', detail)
    this.setData({
      detail: detail || {}
    })
  },

encodeURIComponent() 函数可把字符串作为 URI 组件进行编码。 需要编码传送,解码接收.这样就可以解决字符串长度的问题.如图

列表页面图片

详情页面图片

在这里插入图片描述
————————————————
版权声明:本文为CSDN博主「ze1024」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/ze1024/article/details/120535615

;