axios的get请求传入数组参数原理详解
axios 发送 get 请求
axios 发送 get 请求的一般方式如下:
axios.get(url,{params:{ a:1 }})
但是,如果 params 里有数组参数的话,上面的方法就会带来问题。
例如, 这里发送的请求参数 b 是数组:
axios.get(url,{params:{ a:1, b:[1,2] }})
这时候,后端 Django 用 request.GET.getlist('b')
获取到的参数 b 一直是 []
.
原因
原因是对数组的序列化有多种方式,我们需要前后端统一序列化方式,才能够正确解码。
Django 的 request.GET.getlist('b')
, 对请求参数 b 的序列化要求是这样子的
b=1&b=2
也就是说,用&连接数组中的元素,这并不是 axios 默认的序列化方法。
解决方法
需要指定 axios 的序列化方式,我们可以用 paramsSerializer
参数指定序列化函数。
更简单的方式是使用 qs
库:
import qs from "qs"; axios.get(url,{ params:{ a:1, b:[1,2] }, paramsSerializer: function (params) { return qs.stringify(params, { arrayFormat: "repeat" }); }, })
以上就是axios的get请求传入数组参数原理详解的详细内容,更多关于axios get请求传入数组参数的资料请关注脚本之家其它相关文章!
相关文章
javascript实现数组内值索引随机化及创建随机数组的方法
这篇文章主要介绍了javascript实现数组内值索引随机化及创建随机数组的方法,涉及javascript数组索引及随机数的相关实现技巧,具有一定参考借鉴价值,需要的朋友可以参考下2015-08-08JavaScript实现获取select下拉框中第一个值的方法
这篇文章主要介绍了JavaScript实现获取select下拉框中第一个值的方法,涉及javascript针对页面元素属性的相关获取操作技巧,需要的朋友可以参考下2018-02-02javascript设计模式 – 单例模式原理与应用实例分析
这篇文章主要介绍了javascript设计模式 – 单例模式原理与应用,结合实例形式分析了javascript单例模式原理、定义、应用场景及相关操作注意事项,需要的朋友可以参考下2020-04-04
最新评论