uniapp SyntaxError: Unexpected end of JSON input

文章讲述了在uniapp应用中,由于路由跳转时携带的JSON对象可能存在特殊字符导致的错误。解决方法是先使用JSON.stringify将Object转换为json字符串,然后利用encodeURIComponent进行编码,确保特殊字符被安全替换。在目标页面,接收到参数后,用decodeURIComponent解码并用JSON.parse转换回Object。这样可以避免因特殊字符引起的解析错误。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

报这个错误的原因是,在将Object 转成json时,再转成Object存在非json格式的特殊字符,如&、?,解决的办法是将转成json的字符再用 encodeURIComponent编码一下,将特殊字符替换,之后再替换回来。

1. 我是在uniapp路由跳转携带参数时遇到

<script setup>
//跳转到详情页的方法
const jumpToDetails = ()=>{
    
    let jsonItem = JSON.stringify({
        id:1,name:"张三",
        portart:"https://t7.baidu.com/it/u=2405382010,1555992666&fm=193&f=GIF"
    });
	let encodeData = encodeURIComponent(jsonItem);
	uni.navigateTo({
			url:`/pages/index/articleDetails?item=${encodeData}`
	})
}


//在详情页面接收
import { onLoad } from '@dcloudio/uni-app';
onLoad((option)=>{
    //接收传过来的数据
    let receiveResult = option.item;
    //解码、再转成json 对象
    let obj = JSON.parse(decodeURIComponent(receiveResult))
});
<script>

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

@穷且益坚,不坠青云之志

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值