ajax请求数据包含数组(集合)时需要注意

项目中经常遇到批量删除、批量导出等需求,往往需要把多个id封装成数组传到后台做业务逻辑处理。但是普通ajax请求data参数是数组,后台用数组接收不到。
一般ajax写法

var ids= [];
$.ajax({ 
        url: 'xxxx.do', 
       data: { ids: ids}, 
       dataType: "json", 
       type: "POST", 
       success: function (responseJSON) { 
                alert('Ok'); 
       } 
}); 

这样的写法后台用数组类型接收参数ids为null。经过多方查询解决方案是在ajax请求时加上traditional:true,就可以了。(如下:)

 

$.ajax({ 
    url: 'xxxx.do', 
    data: { ids: ids}, 
    dataType: "json", 
    type: "POST", 
    traditional: true,//这里设为true就可以了
    success: function (responseJSON) { 
        alert('Ok'); 
    } 
}); 

为什么这样写?traditional又是什么意思呢?下面为大家解惑:
一般我们传数参数组时这样写:

data:{arr:[1,2,3]}

如果单纯写成这样,在java后台是无法取到参数的,因为jQuery需要调用jQuery.param序列化参数:jQuery.param( obj, traditional )

默认的话,traditional为false,即jquery会深度序列化参数对象,但servlet api无法处理,我们可以通过设置traditional 为true阻止深度序列化,

然后序列化结果如下:

arr: ["123", "456", "789"] => arr=123&arr=456&arr=456

这样之后,我们就可以在后台通过request.getParameterValues()来获取参数的值数组了。

 

  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值