热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

Thymeleaf的List各类问题(后端接收对象集合)

最近在Thymeleaf做一个页面的时候,因为需要使用List循环展示,提交List到后端,出现各种问题,解决起来也不甚痛苦

 

最近在Thymeleaf做一个页面的时候,因为需要使用List循环展示,提交List到后端,出现各种问题,解决起来也不甚痛苦,这里把解决问题的方式分享一下,也便于自己记录。


介绍:

需求是前端页面循环展示一个后端来的数据,并且前端循环的列表每个都有点击事件,需要把列表中的自己的id传入到触发事件中,最后提交的时候把循环列表的数据全部提交到后端。
我使用的是SpringBoot+Thymeleaf,下面用代码一步步展示过程


1.开始的页面,简单的展示(无循环)

前端:











后端:

@RequestMapping( "/getSchInsTimeByItemsId")public String getSchInsTimeByItemsId(String insItemsId,ModelMap mmap){mmap.put("schInsTime", scheduledApplicationService.getSchInsTimeByItemsId(insItemsId));mmap.put("insItemId", insItemsId);return prefix + "/schInsTime";}

上面是一个简单的跳转页面,展示ModelMap 里的数据的无循环的。url访问xxx/getSchInsTimeByItemsId?insItemsId=xxx 即可跳转到前端页面,如下图


 2.接着需求 需要改成循环列表展示,并且实现可以点击循环的列表,并将其中的id传入触发事件,(贴上前端代码和后端的Controller和实体类代码)











@RequestMapping( "/schInsTimeToView")public String schInsTimeToView(@RequestParam List insItemsIds,ModelMap mmap){mmap.put("schAppInsVOs",scheduledApplicationService.schInsTimeToView(insItemsIds));return prefix + "/schInsTime";}@RequestMapping( "/activeInsTime")@ResponseBodypublic AjaxResult activeInsTime(String insItemsId,Date insActiveTime) throws Exception{Date resultActiveTime = scheduledApplicationService.activeInsTime(insItemsId, insActiveTime);if(resultActiveTime == null){return AjaxResult.success("该时间可以预约");}else{SchApplicationVO schApplicatiOnVO= new SchApplicationVO();schApplicationVO.setApplicationTime(resultActiveTime);schApplicationVO.setInsItemsId(insItemsId);return AjaxResult.warn("该时间已被预约/不在上班时间,已为您调整至最近可预约时间",schApplicationVO);}}

//省略get,set
public class SchApplicationVO implements Serializable {/** 检查项目编码 */private String insItemsId;/** 检查项目名称 */private String insItemsName;private Date applicationTime;
}

 

动图有点不太会弄,凑合看看吧,目前实现了循环展示列表和改变列表中的任意一个都可以把他的id传参


3.最后需求需要改成 需要把选好的循环列表数据提交后端

这里需求后端接收对象集合,这里坑坑了我挺久,先总结下,首先后端需要把 想跟前端交互的对象装成一个List再封装到一个新的类中,前端需要改th:field进行绑定(当然也需要先用th:object解析),最后的最后,因为我这边是时间格式的,从后端过来的格式还需要处理下,具体看代码,在代码中我添加注释加以说明,最后的效果是前端点击提交,后端接收获取得到List数据

 后端代码 (Controller):
 

/*** 获取当前预约的能预约到的预约时间* @param insItemsIds 检查项目id集合* @return*/@RequestMapping( "/schInsTimeToView")public String schInsTimeToView(@RequestParam List insItemsIds,ModelMap mmap){SchApplicationOutWap schApplicatiOnOutWap= new SchApplicationOutWap();schApplicationOutWap.setList(scheduledApplicationService.schInsTimeToView(insItemsIds));mmap.put("schAppInsVOs",schApplicationOutWap);return prefix + "/schInsTime";}/*** 医生主动设置预约时间来预约* @param insItemsId 检查项目id* @param insActiveTime 主动申请预约时间*/@RequestMapping( "/activeInsTime")@ResponseBodypublic AjaxResult activeInsTime(String insItemsId,Date insActiveTime) throws Exception{Date resultActiveTime = scheduledApplicationService.activeInsTime(insItemsId, insActiveTime);if(resultActiveTime == null){return AjaxResult.success("该时间可以预约");}else{SchApplicationVO schApplicatiOnVO= new SchApplicationVO();schApplicationVO.setApplicationTime(resultActiveTime);schApplicationVO.setInsItemsId(insItemsId);return AjaxResult.warn("该时间已被预约/不在上班时间,已为您调整至最近可预约时间",schApplicationVO);}}/*** 确定预约 。前端点提交进入此方法。*/@RequestMapping( "/test")@ResponseBodypublic AjaxResult test(SchApplicationOutWap list){System.out.println(list.getList());return AjaxResult.success();}

这里我们可以看到 schInsTimeToView方法里面我改动了些,增加了SchApplicationOutWap  这个类里面一个外包裹,其实里面就是只有个List的SchApplicationVO的属性


Pojo

public class SchApplicationOutWap implements Serializable {private List list;//省略get set
}

//省略get,set
public class SchApplicationVO implements Serializable {/** 检查项目编码 */private String insItemsId;/** 检查项目名称 */private String insItemsName;// 加上这个可以让前端以此格式输出time@JsonFormat(pattern = "yyyy-MM-dd HH:mm",timezOne="GMT+8")private Date applicationTime;
}

后端想要接收SchApplicationVO对象集合,就必须在其外面再写个对象,像上面这样,才可以跟前端进行绑定(这里本人觉得...一言难尽的设计)

最后附上前端代码:













推荐阅读
  • 向QTextEdit拖放文件的方法及实现步骤
    本文介绍了在使用QTextEdit时如何实现拖放文件的功能,包括相关的方法和实现步骤。通过重写dragEnterEvent和dropEvent函数,并结合QMimeData和QUrl等类,可以轻松实现向QTextEdit拖放文件的功能。详细的代码实现和说明可以参考本文提供的示例代码。 ... [详细]
  • 本文分享了一个关于在C#中使用异步代码的问题,作者在控制台中运行时代码正常工作,但在Windows窗体中却无法正常工作。作者尝试搜索局域网上的主机,但在窗体中计数器没有减少。文章提供了相关的代码和解决思路。 ... [详细]
  • Android JSON基础,音视频开发进阶指南目录
    Array里面的对象数据是有序的,json字符串最外层是方括号的,方括号:[]解析jsonArray代码try{json字符串最外层是 ... [详细]
  • 本文详细介绍了Spring的JdbcTemplate的使用方法,包括执行存储过程、存储函数的call()方法,执行任何SQL语句的execute()方法,单个更新和批量更新的update()和batchUpdate()方法,以及单查和列表查询的query()和queryForXXX()方法。提供了经过测试的API供使用。 ... [详细]
  • IOS开发之短信发送与拨打电话的方法详解
    本文详细介绍了在IOS开发中实现短信发送和拨打电话的两种方式,一种是使用系统底层发送,虽然无法自定义短信内容和返回原应用,但是简单方便;另一种是使用第三方框架发送,需要导入MessageUI头文件,并遵守MFMessageComposeViewControllerDelegate协议,可以实现自定义短信内容和返回原应用的功能。 ... [详细]
  • 本文介绍了如何使用JSONObiect和Gson相关方法实现json数据与kotlin对象的相互转换。首先解释了JSON的概念和数据格式,然后详细介绍了相关API,包括JSONObject和Gson的使用方法。接着讲解了如何将json格式的字符串转换为kotlin对象或List,以及如何将kotlin对象转换为json字符串。最后提到了使用Map封装json对象的特殊情况。文章还对JSON和XML进行了比较,指出了JSON的优势和缺点。 ... [详细]
  • 如何自行分析定位SAP BSP错误
    The“BSPtag”Imentionedintheblogtitlemeansforexamplethetagchtmlb:configCelleratorbelowwhichi ... [详细]
  • Spring源码解密之默认标签的解析方式分析
    本文分析了Spring源码解密中默认标签的解析方式。通过对命名空间的判断,区分默认命名空间和自定义命名空间,并采用不同的解析方式。其中,bean标签的解析最为复杂和重要。 ... [详细]
  • 开发笔记:加密&json&StringIO模块&BytesIO模块
    篇首语:本文由编程笔记#小编为大家整理,主要介绍了加密&json&StringIO模块&BytesIO模块相关的知识,希望对你有一定的参考价值。一、加密加密 ... [详细]
  • 阿,里,云,物,联网,net,core,客户端,czgl,aliiotclient, ... [详细]
  • 本文讨论了一个关于cuowu类的问题,作者在使用cuowu类时遇到了错误提示和使用AdjustmentListener的问题。文章提供了16个解决方案,并给出了两个可能导致错误的原因。 ... [详细]
  • XML介绍与使用的概述及标签规则
    本文介绍了XML的基本概念和用途,包括XML的可扩展性和标签的自定义特性。同时还详细解释了XML标签的规则,包括标签的尖括号和合法标识符的组成,标签必须成对出现的原则以及特殊标签的使用方法。通过本文的阅读,读者可以对XML的基本知识有一个全面的了解。 ... [详细]
  • 本文讨论了Kotlin中扩展函数的一些惯用用法以及其合理性。作者认为在某些情况下,定义扩展函数没有意义,但官方的编码约定支持这种方式。文章还介绍了在类之外定义扩展函数的具体用法,并讨论了避免使用扩展函数的边缘情况。作者提出了对于扩展函数的合理性的质疑,并给出了自己的反驳。最后,文章强调了在编写Kotlin代码时可以自由地使用扩展函数的重要性。 ... [详细]
  • 在springmvc框架中,前台ajax调用方法,对图片批量下载,如何弹出提示保存位置选框?Controller方法 ... [详细]
  • Python爬虫中使用正则表达式的方法和注意事项
    本文介绍了在Python爬虫中使用正则表达式的方法和注意事项。首先解释了爬虫的四个主要步骤,并强调了正则表达式在数据处理中的重要性。然后详细介绍了正则表达式的概念和用法,包括检索、替换和过滤文本的功能。同时提到了re模块是Python内置的用于处理正则表达式的模块,并给出了使用正则表达式时需要注意的特殊字符转义和原始字符串的用法。通过本文的学习,读者可以掌握在Python爬虫中使用正则表达式的技巧和方法。 ... [详细]
author-avatar
美多小涛_584
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有