小程序里面 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 组件进行编码。 需要编码传送,解码接收.这样就可以解决字符串长度的问题.如图
列表页面图片

详情页面图片


当在小程序中使用navigateTo方法传递大量数据时,可能会遇到SyntaxError: Unexpected end of JSON input的报错,这通常是由于参数字符串长度超出限制导致的。为了解决这个问题,可以采取两种策略:1) 仅传递关键ID,在目标页面通过ID获取详细数据;2) 使用encodeURIComponent和decodeURIComponent对数据进行编码和解码,确保字符串长度符合要求。在实际应用中,根据业务需求选择合适的方法可以有效避免此类错误。

7323

被折叠的 条评论
为什么被折叠?



