网站首页 > 技术文章 正文
今天在使用spring boot自带的thymeleaf模板时候,想通过form表单传递一个自定义数组对象给后端接收。可是一直出现问题,后面经过查阅资料后,发现需要把form表单提交的方式,改成ajax方法提交
这个是form表单部分,通过foreach循环,得到多个实体对象
<form action="http://localhost:8080/test/add" method="post" id="fm">
<div class="content">
<div class="item" th:each="paper, userStat:${paperList}">
<div class="paper">
<input type="hidden" name="uid" th:value="${paper.uid}" />
<span>试题</span> <textarea type="text" name="content" th:text="${paper.question}" readonly="true" style="resize:none" ></textarea>
</div>
<div class="answer">
<span>答案</span> <textarea type="text" name="answer" th:text="${paper.content}" style="resize:none" ></textarea>
</div>
</div>
</div>
<div class="submit">
<input type="button" id="submit" value="提交试卷" />
</div>
</form>
下面是把form提交,改成ajax提交方式,手续爱你通过serializeArray()得到序列化数组,然后在对每一条记录进行处理。
$(function() {
function paperTemplate(uid, question, content){
var paper = new Object();
paper.uid = uid;
paper.question = question;
paper.content = content;
return paper;
}
$("#submit").click(function() {
var paperArray = $('#fm').serializeArray();
var paperList = new Array();
for(var i = 0; i < paperArray.length / 3; i++) {
paperList.push(paperTemplate(paperArray[3*i].value, paperArray[3*i + 1].value, paperArray[3*i + 2].value))
}
$.ajax({
type: "POST", //提交的方法
url:"http://localhost:8080/test/add", //提交的地址
data:JSON.stringify(paperList),// 序列化表单值
async: false,
contentType: "application/json;charset=utf-8",//这个参数也是header参数
error: function(request) { //失败的话
alert("Connection error");
},
success: function(data) { //成功
alert(data.data); //就将返回的数据显示出来
}
});
});
})
最后,后端代码为
@ApiOperation(value="新增测试", notes="新增测试")
@ResponseBody
@PostMapping(value="/add")
public String add(@RequestBody Paper [] paperList) {
for(Paper paper : paperList) {
String uid = paper.getUid();
Paper savaPaper = paperService.getById(uid);
if (savaPaper != null && paper.getContent() != null) {
savaPaper.setContent(paper.getContent());
paperService.updateById(savaPaper);
}
}
log.info("提交成功");
return ResultUtil.result(SysConf.SUCCESS, "提交成功");
}
最终通过google浏览器network能够看到,提交的数据
最后还需要注意的一个问题就是thymeleaf在进行编译检测的时候,会很容易编译出错,导致网页不能正常访问。通过查阅资料,发现了这句话。
说明:使用springboot的thymeleaf模板时默认会对HTML进行严格的检查,导致当你的标签没有闭合时就会通不过。nekohtml这个依赖可以解决这一问题。
1)首先需要引入相关的依赖。
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-thymeleaf</artifactId>
</dependency>
<dependency>
<groupId>net.sourceforge.nekohtml</groupId>
<artifactId>nekohtml</artifactId>
<version>1.9.22</version>
</dependency>
2)修改application.yml配置文件
spring:
thymeleaf:
cache: true #关闭缓存
mode: LEGACYHTML5
3) 执行mvn clean install 重新打包启动就可以解决了
猜你喜欢
- 2024-09-30 JavaScript数组_数组方法「二」(二十七)
- 2024-09-30 table组件,前端如何使用table组件打印数组数据
- 2024-09-30 前端数组改字符串方法 前端数组改字符串方法是什么
- 2024-09-30 javascript复制数组的三种方式 javascript复制粘贴
- 2024-09-30 第21节 检测数组、类数组及多维数组-Web前端开发之Javascript
- 2024-09-30 前端系列——ES6中循环数组的方法
- 2024-09-30 前端已死?请用TS写出20个数组方法的声明
- 2024-09-30 带你走进javascript数组的世界 javascript数组操作方法
- 2024-09-30 每天学点 ES6 —— 数组(二) es6数组处理方法
- 2024-09-30 ES6新特性系列之数组解构赋值 es6数组函数
你 发表评论:
欢迎- 最近发表
-
- 前端流行框架Vue3教程:13. 组件传递数据_Props
- 前端必看!10 个 Vue3 救命技巧,解决你 90% 的开发难题?
- JAVA和JavaScript到底是什么关系?是亲戚吗?
- Java和js有什么区别?(java和javascript的区别和联系)
- 东方标准|Web和Java的区别,如何选择这两个专业
- 前端面试题-JS 中如何实现大对象深度对比
- 360前端一面~面试题解析(360前端笔试)
- 加班秃头别慌!1 道 Vue 面试题,快速解锁大厂 offer 通关密码
- 焦虑深夜刷题!5 道高频 React 面试题,吃透 offer 稳了
- 2025Web前端面试题大全(整理版)面试题附答案详解,最全面详细
- 标签列表
-
- 前端设计模式 (75)
- 前端性能优化 (51)
- 前端模板 (66)
- 前端跨域 (52)
- 前端md5加密 (49)
- 前端路由 (55)
- 前端数组 (65)
- 前端定时器 (47)
- 前端懒加载 (45)
- 前端接口 (46)
- Oracle RAC (73)
- oracle恢复 (76)
- oracle 删除表 (48)
- oracle 用户名 (74)
- oracle 工具 (55)
- oracle 内存 (50)
- oracle 导出表 (57)
- oracle查询数据库 (45)
- oracle约束 (46)
- oracle 中文 (51)
- oracle链接 (47)
- oracle的函数 (57)
- mac oracle (47)
- 前端调试 (52)
- 前端登录页面 (48)
本文暂时没有评论,来添加一个吧(●'◡'●)