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";
    

おすすめ

転載: blog.csdn.net/qq_30038111/article/details/109952339