当前位置:   article > 正文

axios的get请求传入数组参数_axios get 数组

axios get 数组

axios 发送 get 请求的一般方式如下:

  1. axios.get(url,{params:{
  2. a:1
  3. }})

但是,如果 params 里有数组参数的话,上面的方法就会带来问题。

例如, 这里发送的请求参数 b 是数组:

  1. axios.get(url,{params:{
  2. a:1,
  3. b:[1,2]
  4. }})

这时候,后端 Django 用 request.GET.getlist('b') 获取到的参数 b 一直是 [].

原因

原因是对数组的序列化有多种方式,我们需要前后端统一序列化方式,才能够正确解码。

Django 的 request.GET.getlist('b') , 对请求参数 b 的序列化要求是这样子的

b=1&b=2

也就是说,用&连接数组中的元素,这并不是 axios 默认的序列化方法。

解决方法

需要指定 axios 的序列化方式,我们可以用 paramsSerializer 参数指定序列化函数。
更简单的方式是使用 qs 库:

  1. import qs from "qs";
  2. axios.get(url,{
  3. params:{
  4. a:1,
  5. b:[1,2]
  6. },
  7. paramsSerializer: function (params) {
  8. return qs.stringify(params, { arrayFormat: "repeat" });
  9. },
  10. })

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/weixin_40725706/article/detail/924657
推荐阅读
  

闽ICP备14008679号