springboot中前端ajax如何给controller提交数组参数?

说明

我有个需求,前端批量添加一堆商品明细。也就是说会有一个商品ID,然后一堆商品明细,多行。
如此一来,针对后端接口肯定是要以数组或列表方式接收这个商品明细数组了。

前端代码

关键地方在于以formdata形式请求:
在这里插入图片描述

// 以换行符作为分隔出一个数组
var arr =  data.field.kms.split('\n');

$.ajax({
    url: ctx+'/km/addBatch',
    type: "POST",
    dataType: "json",
    data:  {"goodsId": $("#goodsId").val(), "kms": arr},
    success: function (data) {
        layer.closeAll();//关闭所有的弹出层
        table.reload('kmTab');
    }
});

接口代码

核心就是: @RequestParam(“kms[]”) String[] kms
为什么要指定参数名称是 kms[]
因为前端是以formdata形式提交的数据,仔细看下谷歌浏览器中请求参数情况一目了然:
在这里插入图片描述

@PostMapping("/addBatch")
@ResponseBody
public Result<String> addBatch(Integer goodsId, @RequestParam("kms[]") String[] kms){
    List<GoodsItem> list = new ArrayList<>();
    GoodsItem entity = null;
    for (int i = 0; i < kms.length; i++) {
        entity = new GoodsItem();
        entity.setGoodsId(goodsId);
        entity.setKm(kms[i]);
        entity.setCreateTime(new Date());

        list.add(entity);
    }

    goodsItemService.saveBatch(list);

    return ResultUtil.ok();
}
posted @ 2021-05-25 14:46  一锤子技术员  阅读(19)  评论(0编辑  收藏  举报  来源