Thymeleaf常用语法:数据迭代
2019-10-18 08:37:27来源:博客园 阅读 ()
Thymeleaf数据迭代使用th:each属性,可以迭代数组、List、Set和Map等,数组、List、Set的迭代方法类似,迭代Map则会得到一个java.util.Map.Entry对象。
在迭代过程中,还可以获取迭代状态的变量,如迭代索引、数据集合大小等等。
开发环境:IntelliJ IDEA 2019.2.2
Spring Boot版本:2.1.8
新建一个名称为demo的Spring Boot项目。
1、pom.xml
加入Thymeleaf依赖
<dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-thymeleaf</artifactId> </dependency>
2、src/main/java/com/example/demo/user.java
package com.example.demo; public class User { Integer id; String name; public User(Integer id, String name) { this.id = id; this.name = name; } public Integer getId() { return id; } public void setId(Integer id) { this.id = id; } public String getName() { return name; } public void setName(String name) { this.name = name; } }
3、src/main/java/com/example/demo/TestController.java
package com.example.demo; import org.springframework.stereotype.Controller; import org.springframework.ui.Model; import org.springframework.web.bind.annotation.RequestMapping; import java.util.ArrayList; import java.util.HashMap; import java.util.List; import java.util.Map; @Controller public class TestController { @RequestMapping("/") public String test(Model model){ List<User> users = new ArrayList<User>(); users.add(new User(1,"张三")); users.add(new User(2,"李四")); users.add(new User(3,"王五")); model.addAttribute("users", users); Map<String, User> userMap = new HashMap<String,User>(); userMap.put("a", new User(4, "赵六")); userMap.put("b", new User(5, "钱七")); model.addAttribute("userMap", userMap); return "test"; } }
4、src/main/resources/templates/test.html
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Title</title> <style type="text/css"> table { border-collapse:collapse;} td { border: 1px solid #C1DAD7;} </style> </head> <body> <div>迭代List</div> <table> <tr th:each="user : ${users}"> <td th:text="${user.id}"></td> <td th:text="${user.name}"></td> </tr> </table> <div>迭代Map</div> <table> <tr th:each="map : ${userMap}"> <td th:text="${map.key} + |--| + ${map.value.id} + |--| + ${map.value.name}"></td> </tr> </table> <div>迭代状态对象</div> <table> <tr th:each="data,iterState : ${#numbers.sequence(0,2)}" th:style="|background-color:| + ${iterState.odd ? 'while' : 'gray'}"> <td th:text="|从0开头的索引:| + ${iterState.index}"></td> <td th:text="|从1开头的索引:| + ${iterState.count}"></td> <td th:text="|数据集合大小:| + ${iterState.size}"></td> <td th:text="|当前节点:| + ${iterState.current}"></td> <td th:text="|是否第一次迭代:| + ${iterState.first}"></td> <td th:text="|是否最后一次迭代:| + ${iterState.last}"></td> <td th:text="|是否偶数迭代:| + ${iterState.even}"></td> <td th:text="|是否奇数迭代:| + ${iterState.odd}"></td> </tr> </table> 上面的iterState是显式声明的迭代状态对象,也可以按默认规划“节点变量名+Stat”获取 <table> <tr th:each="data : ${#numbers.sequence(0,2)}" th:style="|background-color:| + ${dataStat.odd ? 'while' : 'gray'}"> <td th:text="${data}"></td> </tr> </table> <table> <tr th:each="user : ${users}" th:style="|background-color:| + ${userStat.odd ? 'while' : 'gray'}"> <td th:text="${user.id}"></td> <td th:text="${user.name}"></td> </tr> </table> </body> </html>
浏览器访问:http://localhost:8080,截图如下:
右键查看网页源代码,生成的HTML源码:
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Title</title> <style type="text/css"> table { border-collapse:collapse;} td { border: 1px solid #C1DAD7;} </style> </head> <body> <div>迭代List</div> <table> <tr> <td>1</td> <td>张三</td> </tr> <tr> <td>2</td> <td>李四</td> </tr> <tr> <td>3</td> <td>王五</td> </tr> </table> <div>迭代Map</div> <table> <tr> <td>a--4--赵六</td> </tr> <tr> <td>b--5--钱七</td> </tr> </table> <div>迭代状态对象</div> <table> <tr style="background-color:while"> <td>从0开头的索引:0</td> <td>从1开头的索引:1</td> <td>数据集合大小:3</td> <td>当前节点:0</td> <td>是否第一次迭代:true</td> <td>是否最后一次迭代:false</td> <td>是否偶数迭代:false</td> <td>是否奇数迭代:true</td> </tr> <tr style="background-color:gray"> <td>从0开头的索引:1</td> <td>从1开头的索引:2</td> <td>数据集合大小:3</td> <td>当前节点:1</td> <td>是否第一次迭代:false</td> <td>是否最后一次迭代:false</td> <td>是否偶数迭代:true</td> <td>是否奇数迭代:false</td> </tr> <tr style="background-color:while"> <td>从0开头的索引:2</td> <td>从1开头的索引:3</td> <td>数据集合大小:3</td> <td>当前节点:2</td> <td>是否第一次迭代:false</td> <td>是否最后一次迭代:true</td> <td>是否偶数迭代:false</td> <td>是否奇数迭代:true</td> </tr> </table> 上面的iterState是显式声明的迭代状态对象,也可以按默认规划“节点变量名+Stat”获取 <table> <tr style="background-color:while"> <td>0</td> </tr> <tr style="background-color:gray"> <td>1</td> </tr> <tr style="background-color:while"> <td>2</td> </tr> </table> <table> <tr style="background-color:while"> <td>1</td> <td>张三</td> </tr> <tr style="background-color:gray"> <td>2</td> <td>李四</td> </tr> <tr style="background-color:while"> <td>3</td> <td>王五</td> </tr> </table> </body> </html>
原文链接:https://www.cnblogs.com/gdjlc/p/11695788.html
如有疑问请与原作者联系
标签:
版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有
上一篇:Java之路---Day01
下一篇:Java工程师学习指南(完结篇)
- 04.Java基础语法 2020-06-11
- Java基础语法菜鸟教程笔记 2020-06-10
- Java 必须掌握的 12 种 Spring 常用注解! 2020-06-08
- JAVA中常用的类 2020-06-05
- (易忘篇)java基本语法难点2 2020-06-03
IDC资讯: 主机资讯 注册资讯 托管资讯 vps资讯 网站建设
网站运营: 建站经验 策划盈利 搜索优化 网站推广 免费资源
网络编程: Asp.Net编程 Asp编程 Php编程 Xml编程 Access Mssql Mysql 其它
服务器技术: Web服务器 Ftp服务器 Mail服务器 Dns服务器 安全防护
软件技巧: 其它软件 Word Excel Powerpoint Ghost Vista QQ空间 QQ FlashGet 迅雷
网页制作: FrontPages Dreamweaver Javascript css photoshop fireworks Flash