在web开发中,get方式是http协议中最常见的传递数据方式,然而get方法只能将数据附加到url中进行传输,而无法像post方法那样将数据放在请求体中,因此从安全性和数据长度等方面考虑,若要传递较大的json数据,需要以某种方式将数据转换成url中能识别的形式进行传输。
一种解决方案就是使用encodeURI()函数将json数据进行编码,然后将编码后的字符串放在url中进行get传输。代码如下:
let jsonData = {name: '张三', age: 20, gender: '男'} let url = 'http://www.example.com/getData?data=' + encodeURI(JSON.stringify(jsonData))
在以上代码中,JSON.stringify方法将jsonData对象转换成json字符串,再通过encodeURI函数将字符串进行编码,最后将编码后的字符串附加在url的后面传递给服务器端。当服务器端接收到请求时,需要将url中的参数进行解码,并将解码后的字符串转换成json对象进行处理。代码如下:
let urlParams = new URLSearchParams(window.location.search) let dataStr = urlParams.get('data') let jsonData = JSON.parse(decodeURI(dataStr)) console.log(jsonData) // {name: '张三', age: 20, gender: '男'}
在以上代码中,URLSearchParams对象可以获取到url中的参数,get方法可以获取data参数的值,decodeURI函数将data参数进行解码,JSON.parse方法将字符串转换成json对象,最终获取到jsonData对象。
需要注意的是,由于url长度的限制,get方法传输的json数据大小应该控制在合理范围内。若需要传输较大的数据,应该使用post方法等其他传输方式。