thymeleaf也是一模板技术,与freemarker类似,本文讲述springboot如何整合thymeleaf。
1、环境约束
- win10 64位操作系统
- idea2018.1.5
- maven-3.0.5
- jdk-8u162-windows-x64
2、前提约束
- 完成springboot创建web项目 https://www.jianshu.com/p/de979f53ad80
注意:笔者创建项目的时候约束的包前缀是net.wanho.springboot.thymeleaf,读者可以自行创建包名,只是要注意本文中的代码也要修改包名
3、修改pom.xml
在dependencies标签中加入以下依赖:
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-thymeleaf</artifactId>
</dependency>
4、在net.wanho.springboot.thymeleaf包下面创建controller、entity子包
在entity下创建User.java
package net.wanho.springboot.thymeleaf.entity;
public class User {
private Integer id;
private String name;
public User(Integer id, String name) {
this.id = id;
this.name = name;
}
public User() {
}
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;
}
}
在controller下创建UserController.java
package net.wanho.springboot.thymeleaf.controller;
import net.wanho.springboot.thymeleaf.entity.User;
import org.springframework.stereotype.Controller;
import org.springframework.ui.Model;
import org.springframework.web.bind.annotation.RequestMapping;
import java.util.ArrayList;
import java.util.List;
@Controller
@RequestMapping("/user")
public class UserController {
@RequestMapping("/list")
public String listUser(Model model) {
List<User> userList = new ArrayList<User>();
for (int i = 0; i <10; i++) {
userList.add(new User(i,"ali "+i));
}
model.addAttribute("users", userList);
return "/user/list";
}
}
5、在resources/templates/user下创建list.html【注意,依赖的css,js需要读者自行导入】
<!DOCTYPE html>
<html xmlns:th="http://www.thymeleaf.org">
<head>
<meta charset="UTF-8"/>
<title>Insert title here</title>
<link rel="stylesheet" href="/css/bootstrap.min.3.3.5.css"/>
<script src="/js/jquery-1.11.2.min.js" type="text/javascript"></script>
<script src="/js/bootstrap.js" type="text/javascript"></script>
</head>
<body>
<div>
<table class="table">
<caption>用户基本信息</caption>
<thead>
<tr>
<th>id</th>
<th>姓名</th>
</tr>
</thead>
<tbody th:each="user:${users}">
<tr>
<td th:text="${user.id}"></td>
<td th:text="${user.name}"></td>
</tr>
</tbody>
</table>
</div>
</body>
</html>
6、启动测试
在浏览器中输入http://localhost:8080/user/list,查看效果,具体情况如下:
至此,我们完成了springboot对thymeleaf的支持,并完成了测试。