js构建form表单数据

背景

后端接口:参数为PersonPerson成员变量包含Other对象

@RequestMapping("post")
public Object post(Person person) {
    return JsonResult.success(person);
}

public class Person implements Serializable {
    private Other other;
    private String name;
    private Integer age;
}
public class Other implements Serializable {
    private String name;
    private String add;
}

接口文档

参数
name
age
other.name
other.add

前端解释说:js根本不支持“.”运算符,也就是说js不支持other.name这种格式的key。当时我很诧异,可能是我接口描述不够清晰?可是我已经给出例子了。前端还是个高级开发,也许我是从乡下来的,城里猿没接触过?
这种格式的数据,我之前对接的很多前端,都认识。我直接不跟他争论,用事实说话。

前端js代码

其实前端构建Form表单数据,方法有很多中。

  • 前端本来就使用form表单创建的表格

    var data = $("#addForm").serialize(); 
    
  • 使用FormData构建表单数据

    var data = new FormData();
    //FormData对象加入参数
    data.append('name', 'name1');
    data.append('age', 18);
    data.append('other.name', 'name2');
    data.append('add', 'add1');
    
  • 手动构建表单数据

    var content = {};
    content['age'] = 18;
    content['name'] = 'name';
    content['other.name'] = 'other name';
    content['other.add'] = 'other add';
    
    
    var content = {
        "name": "name",
        "age": 18,
        "other.name": "other name",
        "other.add": "other add"
    }
    
  • 手动构建表单数据(错误示例),后端会报错,spring会把other当成数组

    var content = {};
    content.age = 18;
    content.name = 'name';
    content.other = {};
    content.other.name = 'other name';
    content.other.add = "other add";
    
  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值