前端代码:

<form id="person_add" method="post" action="user">
<table class="table_add">
<tr>
<td>
</td>
<td>name:</td>
<td><input name="name" value=""/></td>
<td>address</td>
<td><input name="address" value=""/></td>
</tr>
<tr>
<td></td>
<td>name:</td>
<td><input name="name" value=""/></td>
<td>address</td>
<td><input name="address" value=""/></td>
</tr>
<tr>
<td></td>
<td>name:</td>
<td><input name="name" value=""/></td>
<td>address</td>
<td><input name="address" value=""/></td>
</tr>
<tr>
<td></td>
<td>name:</td>
<td><input name="name" value=""/></td>
<td>address</td>
<td><input name="address" value=""/></td>
</tr>
<tr align="center">
<td colspan="5">
<a id="menu_submit" href="javascript:onSubmit()">提交</a>
<a id="menu_no" href="javascript:closeDialog()">关闭</a>
</td>
</tr>
</table>
</form>

Controller代码:

    @PutMapping
public void addUser(@RequestBody List<Person> persons){
System.out.println(persons.toString());
}

如果后台使用Controller这样接收参数,那么必须传递进来参数如下格式:

[{"name":"1","address":"a1"},{"name":"2","address":"b1"},{"name":"3","address":"c1"},{"name":"4","address":"d1"}]

首先对表单进行序列化,

 $.serializeObject = function (form) {
var o = {};
$.each(form.serializeArray(), function (index) {
if (o[this['name']]) {
if ($.isArray(o[this['name']])) {
o[this['name']].push(this['value']);
} else {
o[this['name']] = [o[this['name']], this['value']];
}
} else {
o[this['name']] = this['value'];
}
});
return o;
};

序列化之后的表单是一个对象,通过调用,得到一个对象

var serializeArray = $.serializeObject($("#person_add"));

将对象分解成为我们需要的json字符串,JSON.stringify() 将对象转为字符串

 // 计算json内部的数组最大长度,必须要有这一步
for (var item in serializeArray) {
var tmp = $.isArray(serializeArray[item]) ? serializeArray[item].length : 1;
vCount = (tmp > vCount) ? tmp : vCount;
} if (vCount > 1) {
var jsonData2 = new Array();
for (var i = 0; i < vCount; i++) {
var jsonObj = {};
for (var item in serializeArray) {
jsonObj[item] = serializeArray[item][i];
}
jsonData2.push(jsonObj);
}
jsonParams=JSON.stringify(jsonData2);
} else {
jsonParams=JSON.stringify(serializeArray);
};
console.info(jsonParams);

得到的jsonParams就是我们需要的json字符串

通过ajax直接上传即可:

 $.ajax({
url: "user",
method: "PUT",
contentType: "application/json; charset=utf-8",
data: jsonParams,
success: function (res) {
alert(res);
}
})

【springmvc】之使用jQuery接收前端传入List对象的更多相关文章

  1. SpringMVC接收前端传值有哪些方式?

    有很多种,比如: 1.通过@RequestParam注解接收请求参数: 2.通过Bean封装,接收多个请求参数 3.通过@ModelAttribute绑定接收前端表单数据 4.通过@PathVaria ...

  2. (转)springMVC框架下JQuery传递并解析Json数据

    springMVC框架下JQuery传递并解析Json数据 json作为一种轻量级的数据交换格式,在前后台数据交换中占据着非常重要的地位.Json的语法非常简单,采用的是键值对表示形式.JSON 可以 ...

  3. 使用JQuery将前端form表单数据转换为JSON字符串传递到后台处理

    一般地,我们在处理表单(form表单哦)数据时,传输对象或字符串到后台,Spring MVC或SpringBoot的Controller接收时使用一个对象作为参数就可以被正常接收并封装到对象中.这种方 ...

  4. spring MVC 如何接收前台传入的JSON对象数组并处理

    spring MVC 如何接收前台传入的JSON对象数组 主要方法: (主要用到的包是 net.sf.json  即:json-lib-2.3-jdk15.jar 完整相关jar包: commons- ...

  5. spring MVC 如何接收前台传入的JSON对象数组

    spring MVC 如何接收前台传入的JSON对象数组 主要方法: (主要用到的包是 net.sf.json  即:json-lib-2.3-jdk15.jar 完整相关jar包: commons- ...

  6. springMVC框架下JQuery传递并解析Json数据

    springMVC框架下JQuery传递并解析Json数据

  7. MVC应用程序使用jQuery接收Url的参数

    在这个练习<MVC应用jQuery动态产生数据>http://www.cnblogs.com/insus/p/3410138.html 中,学会了使用jQuery创建url链接,并设置了参 ...

  8. 【转】jQuery之前端国际化jQuery.i18n.properties

    jQuery之前端国际化jQuery.i18n.properties 基于jQuery.i18n.properties 实现前端页面的资源国际化 jquery-i18n-properties

  9. 基于JQuery的前端form表单操作

    Jquery的前端表单操作:     jquery提供了良好的方法封装,在一些基本的操作的时候,能节省很多的麻烦,其中,在具体使用时,form表单的数据提交是最频繁也最常见的前后数据交换方式,所以在前 ...

随机推荐

  1. Ubuntu配置Github并且新建仓库push代码,从已有仓库clone代码,并且push

    Github是一款良好的管理代码的工具,使用的时候需要现在Ubuntu上进行配置,下面的内容分为三个部分,第一部分讲述如何在之前从未配置github的电脑配置github,第二部分讲述如何在远程新建一 ...

  2. 字符串(text)格式的html代码文本转为DOM对象

    /*字符串转dom对象*/ window.strimgTurnDom = function(txt) { try //Internet Explorer { xmlDoc=new ActiveXObj ...

  3. input标签(按钮)

    按钮: <input type="button" name="..." value="..." /> <input typ ...

  4. s21day05 python笔记

    s21day05 python笔记 一.昨日内容回顾及补充 回顾 补充 列表独有功能 extend:循环添加到一个列表中 1.users = ['张三',66],people = ['王五',99] ...

  5. python---map 用法 [转载]

    map()函数 map()是 Python 内置的高阶函数,它接收一个函数 f 和一个 list,并通过把函数 f 依次作用在 list 的每个元素上,得到一个新的 list 并返回. 1.当seq只 ...

  6. webpack的一些详细配置

    http://blog.csdn.net/c_kite/article/details/71279853

  7. 2017.4.5 OpenStack简介

    OpenStack 管理的资源不是单机的而是一个分布的系统,把分布的计算.存储.网络.设备.资源组织起来,形成一个完整的云计算系统:OpenStack 也提供一个 UI,这里包括一个图形化的 UI:H ...

  8. Washing Text Animation

    https://www.youtube.com/watch?v=q0_koJLc0OgBlender Tutorial: Washing Text Animation 需要用到插件, 进入用户设置的插 ...

  9. redis 部署相关

    ★ 启动: 配置好环境变量后:打开一个cmd窗口,执行redis-server.exe就可以启动redis了. https://blog.csdn.net/weixin_42423819/articl ...

  10. 给新创建的用户 赋予所有的权利 *.* 查看权限 删除用户 ---------DCL用户权限管理篇

    第一步:进入数据库以后,先用 show databases; 再use mysql;    再 show tables;    再 select user,host from mysql.user; ...