"在目前的企业级应用开发中,前后端分离是主流,Spring Boot 对视图层技术提供了很好的支持,官方推荐使用的模板引擎是 Thymeleaf 不过像 FreeMarker 也支持,JSP 技术不再推荐使用。 1. 新建 Spring Boot 工程,然后添加 spring-boot-starter-web 和 spr .."

Spring Boot 整合 Thymeleaf

在目前的企业级应用开发中,前后端分离是主流,Spring Boot 对视图层技术提供了很好的支持,官方推荐使用的模板引擎是 Thymeleaf 不过像 FreeMarker 也支持,JSP 技术不再推荐使用。

1. 新建 Spring Boot 工程,然后添加 spring-boot-starter-web 和 spring-boot-starter-thymeleaf 依赖,代码如下:

<dependency>
	<groupId>org.springframework.boot</groupId>
	<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
	<groupId>org.springframework.boot</groupId>
	<artifactId>spring-boot-starter-thymeleaf</artifactId>
</dependency>

2. 配置 Thymeleaf,通过 application.properties 配置文件进行设置。代码如下:

#是否开启缓存,开发时可设置为 false ,默认为 true
spring.thymeleaf.cache=false 
#检查模板是否存在,默认为 true
spring.thymeleaf.check-template=true 
#检查模板位置是否存在,默认为 true
spring.thymeleaf.check-template-location=true 
#模板文件编码
spring.thymeleaf.encoding=UTF-8
#模板文件位置
spring.thymeleaf.prefx=classpath /templates/
#Content Type 配置
spring.thymeleaf.servlet.content-type=text/html 
#模板文件后缀
spring.thymeleaf.suffix=.html

3. 创建 Book 实体类,然后在 Controller 中返回 ModelAndVi ew ,代码如下:

public class Book {
    private Integer id;
    private String name;
    private String author;

    @Override
    public String toString() {
        return "Book{" +
                "id=" + id +
                ", name='" + name + '\'' +
                ", author='" + author + '\'' +
                '}';
    }

    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;
    }

    public String getAuthor() {
        return author;
    }

    public void setAuthor(String author) {
        this.author = author;
    }

@Controller
public class BookController {
    @GetMapping("/books")
    public ModelAndView books(){
        List<Book> books=new ArrayList<>();
        Book b1=new Book();
        b1.setId(1);
        b1.setAuthor("罗贯中");
        b1.setName("三国演义");
        Book b2=new Book();
        b2.setId(2);
        b2.setAuthor("曹雪芹");
        b2.setName("红楼梦");
        books.add(b1);
        books.add(b2);

        ModelAndView mv=new ModelAndView();
        mv.addObject("books",books);
        mv.setViewName("books");
        return mv;
    }
}

4. 在 resources 目录下的 templates 录中创建 books.html 具体代码如下:

<!DOCTYPE html>
<html lang="en" xmlns:th="http://www.thymeleaf.org">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>
<table border="1">
    <tr>
        <td>图书编号</td>
        <td>图书名称</td>
        <td>图书作者</td>
    </tr>
    <tr th:each="book:${books}">
        <td th:text="${book.id}"></td>
        <td th:text="${book.name}"></td>
        <td th:text="${book.author}"></td>
    </tr>
</table>
</body>
</html>

5. 运行项目,在浏览器中输入 http://localhost:8080/books 即可看到运行结果,如图所示。

4.jpg

本文重点介绍 Spring Boot 整合 Thymeleaf 并非 Thymeleaf 的基础用法,关于 Thymeleaf 的更多资料,可以查看 https://www.thymeleaf.org

  • Spring

    Spring 是一个开源框架,是于 2003 年兴起的一个轻量级的 Java 开发框架,由 Rod Johnson 在其著作《Expert One-On-One J2EE Development and Design》中阐述的部分理念和原型衍生而来。它是为了解决企业应用开发的复杂性而创建的。框架的主要优势之一就是其分层架构,分层架构允许使用者选择使用哪一个组件,同时为 JavaEE 应用程序开发提供集成的框架。

    549 引用 • 1163 回帖 • 905 关注
  • Thymeleaf

    Thymeleaf 是一款用于渲染 XML/XHTML/HTML5 内容的模板引擎。类似 Velocity、 FreeMarker 等,它也可以轻易的与 Spring 等 Web 框架进行集成作为 Web 应用的模板引擎。与其它模板引擎相比,Thymeleaf 最大的特点是能够直接在浏览器中打开并正确显示模板页面,而不需要启动整个 Web 应用。

    9 引用 • 19 回帖 • 265 关注
感谢    关注    收藏    赞同    反对    举报    分享
回帖    
请输入回帖内容...