小程序开发过程中,有时候需要传较长的数据到下一个页面,但是小程序的参数长度是有限制的,过长会报错,用以下方法解决
// ----------方法一-----------
//当前页
const item= this.list[0]
// 将对象转成JSON字符串 再编码
let current_url=encodeURIComponent(JSON.stringify(url))
wx.navigateTo({
url:'/pages/otherPage/otherPage?data=${current_url}'
})
//另一个页面
// 先对参数解码
let data=decodeURIComponent(options.data);
//将JSON字符串转成对象
let obj=JSON.parse(data)
// ----------方法二-----------
// 将对象转成JSON字符串
let obj = { /* 这里是你的对象 */ };
let objStr = JSON.stringify(obj);
// 将JSON字符串转成Base64编码
let base64Str = window.btoa(objStr);
// 将Base64编码传参到另一个页面
wx.navigateTo({
url: '/pages/otherPage/otherPage?data=' + base64Str
});
// 获取传递过来的Base64编码
let base64Str = options.data;
// 将Base64编码解码成JSON字符串
let objStr = window.atob(base64Str);
// 将JSON字符串转成对象
let obj = JSON.parse(objStr);
第二种方法一般不推荐使用;容易出现Failed to execute 'btoa' on 'Window': The string to be encoded contains characters outside of the Latin1 range错误(报错信息中指出字符串中包含了Latin1范围之外的字符,导致无法使用window.btoa进行解析。这些字符属于Unicode字符集,超出了Latin1范围。)