【springmvc】之使用jQuery接收前端传入List对象
前端代码:
<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对象的更多相关文章
- SpringMVC接收前端传值有哪些方式?
有很多种,比如: 1.通过@RequestParam注解接收请求参数: 2.通过Bean封装,接收多个请求参数 3.通过@ModelAttribute绑定接收前端表单数据 4.通过@PathVaria ...
- (转)springMVC框架下JQuery传递并解析Json数据
springMVC框架下JQuery传递并解析Json数据 json作为一种轻量级的数据交换格式,在前后台数据交换中占据着非常重要的地位.Json的语法非常简单,采用的是键值对表示形式.JSON 可以 ...
- 使用JQuery将前端form表单数据转换为JSON字符串传递到后台处理
一般地,我们在处理表单(form表单哦)数据时,传输对象或字符串到后台,Spring MVC或SpringBoot的Controller接收时使用一个对象作为参数就可以被正常接收并封装到对象中.这种方 ...
- spring MVC 如何接收前台传入的JSON对象数组并处理
spring MVC 如何接收前台传入的JSON对象数组 主要方法: (主要用到的包是 net.sf.json 即:json-lib-2.3-jdk15.jar 完整相关jar包: commons- ...
- spring MVC 如何接收前台传入的JSON对象数组
spring MVC 如何接收前台传入的JSON对象数组 主要方法: (主要用到的包是 net.sf.json 即:json-lib-2.3-jdk15.jar 完整相关jar包: commons- ...
- springMVC框架下JQuery传递并解析Json数据
springMVC框架下JQuery传递并解析Json数据
- MVC应用程序使用jQuery接收Url的参数
在这个练习<MVC应用jQuery动态产生数据>http://www.cnblogs.com/insus/p/3410138.html 中,学会了使用jQuery创建url链接,并设置了参 ...
- 【转】jQuery之前端国际化jQuery.i18n.properties
jQuery之前端国际化jQuery.i18n.properties 基于jQuery.i18n.properties 实现前端页面的资源国际化 jquery-i18n-properties
- 基于JQuery的前端form表单操作
Jquery的前端表单操作: jquery提供了良好的方法封装,在一些基本的操作的时候,能节省很多的麻烦,其中,在具体使用时,form表单的数据提交是最频繁也最常见的前后数据交换方式,所以在前 ...
随机推荐
- unity ugui Toggle Group详解(Chinar出品、简单易懂)
UGUI Toggle Group用法教程 本文提供全流程,中文翻译. Chinar 坚持将简单的生活方式,带给世人!(拥有更好的阅读体验 -- 高分辨率用户请根据需求调整网页缩放比例) Chinar ...
- select标签(分组下拉菜单和列表)
分组下拉菜单和列表标签: <select name=" " > <optgroup label="组1"> <option val ...
- jQ常用选择器
#id: $('#div'); //查找id='div'; .class: $('.myclass'); //查找class='myclass'; element:用于搜索的元素,指向DOM节 ...
- 博客 first
2016.10.28 这会是一个值得纪念的日子,我将会从此刻开始,1~2天不间断的更新我再软件,编程方面的学习历程和在大学的琐事. 希望N年后看到,能够回味. a good memery....... ...
- 重写ajax方法实现请求session过期时跳转登录页面
jQuery(function($){ var _ajax=$.ajax; // 备份jquery的ajax方法 $.ajax=function(opt){ var _success = opt &a ...
- 【BZOJ4720】【NOIP2016】换教室
我当年真是naive…… 原题: 对于刚上大学的牛牛来说,他面临的第一个问题是如何根据实际情况申请合适的课程.在可以选择的课程中,有2n节 课程安排在n个时间段上.在第i(1≤i≤n)个时间段上,两节 ...
- 【BZOJ4300】 绝世好题
傻逼题都不能一眼看出思路…… 原题: 给定一个长度为n的数列ai,求ai的子序列bi的最长长度,满足bi&bi-1!=0(2<=i<=len). n<=100000,ai&l ...
- Easyui datagrid 去掉表头的checkbox复选框
$(".datagrid-header-check").html(""); 在onLoadSuccess中加入此行代码即可实现datagrid去除表头的chec ...
- Singer 学习十一 配置以及状态管理
配置和状态文件通过提供身份验证信息,开始时间和有关以前调用的信息,帮助为Taps和Targets提供上下文 配置文件 配置文件包含tap 运行需要的信息,通常包含API,以及数据源的凭据 特殊字段 s ...
- deno学习三 官方提供的方便deno 安装方式
早起deno 使用了golang 开发,同时需要protobuf 进行数据的序列化以及反序列化处理 当前的deno 已经使用rust 进行了开发,同时官方提供的安装方式也很方便了,不需要 那么复杂的编 ...