Thymeleaf入门学习教程

Thymeleaf 是一个现代化的服务器端 Java 模板引擎,适用于 Web 和独立环境。它能够处理 HTML、XML、JavaScript、CSS 甚至纯文本。Thymeleaf 的主要目标是提供一种优雅且高度可维护的模板创建方式。为了实现这一目标,它以自然模板的概念为基础,将模板文件作为原型,这意味着它们可以在浏览器中直接打开并正确显示,而无需通过服务器渲染。

1. 环境搭建

首先,确保你的开发环境中已经安装了 Java 和 Maven(或 Gradle)。然后,你可以在 Maven 项目的 pom.xml 文件中添加 Thymeleaf 的依赖:

xml 复制代码
<dependency>
    <groupId>org.thymeleaf</groupId>
    <artifactId>thymeleaf</artifactId>
    <version>3.0.12.RELEASE</version>
</dependency>

2. 基本配置

在使用 Thymeleaf 之前,你需要配置一个 TemplateEngine 对象,这是 Thymeleaf 的核心类,用于处理模板。

java 复制代码
import org.thymeleaf.TemplateEngine;
import org.thymeleaf.templateresolver.ClassLoaderTemplateResolver;

public class ThymeleafConfig {
    public static TemplateEngine getTemplateEngine() {
        TemplateEngine templateEngine = new TemplateEngine();
        ClassLoaderTemplateResolver templateResolver = new ClassLoaderTemplateResolver();
        templateResolver.setPrefix("/templates/"); // 模板文件存放的路径
        templateResolver.setSuffix(".html");       // 模板文件的后缀
        templateResolver.setTemplateMode("HTML5"); // 模板模式
        templateResolver.setCharacterEncoding("UTF-8"); // 编码
        templateEngine.setTemplateResolver(templateResolver);
        return templateEngine;
    }
}

3. 创建模板

src/main/resources/templates 目录下创建一个 HTML 文件,例如 hello.html

html 复制代码
<!DOCTYPE html>
<html xmlns:th="http://www.thymeleaf.org">
<head>
    <title>Thymeleaf 示例</title>
</head>
<body>
    <h1 th:text="${message}">默认消息</h1>
</body>
</html>

4. 渲染模板

在 Java 代码中使用 TemplateEngine 来渲染模板:

java 复制代码
import org.thymeleaf.TemplateEngine;
import org.thymeleaf.context.Context;

public class ThymeleafExample {
    public static void main(String[] args) {
        TemplateEngine templateEngine = ThymeleafConfig.getTemplateEngine();
        Context context = new Context();
        context.setVariable("message", "你好,Thymeleaf!");
        String renderedHtml = templateEngine.process("hello", context);
        System.out.println(renderedHtml);
    }
}

5. 运行程序

运行上述 Java 程序,你将在控制台看到渲染后的 HTML 内容:

html 复制代码
<!DOCTYPE html>
<html>
<head>
    <title>Thymeleaf 示例</title>
</head>
<body>
    <h1>你好,Thymeleaf!</h1>
</body>
</html>

6. 常用语法

  • 变量表达式${...},用于在模板中插入变量的值。
  • 选择表达式*{...},用于选择当前对象中的属性。
  • 消息表达式#{...},用于国际化消息。
  • 链接表达式@{...},用于生成 URL。
  • 片段表达式~{...},用于包含模板片段。

7. 进阶学习

  • 布局和片段 :使用 th:fragmentth:replace 来实现模板的复用。
  • 条件判断 :使用 th:ifth:unless 进行条件渲染。
  • 循环 :使用 th:each 进行循环渲染。
  • 表单处理 :使用 th:objectth:field 处理表单数据。

8. 参考文档

通过以上步骤,你应该能够掌握 Thymeleaf 的基本用法,并开始在你的项目中使用它来创建动态的 Web 页面。

相关推荐
remember_me20 分钟前
LangGraph 使用指南
后端
ILYT NCTR20 分钟前
搭建Golang gRPC环境:protoc、protoc-gen-go 和 protoc-gen-go-grpc 工具安装教程
开发语言·后端·golang
花椒技术34 分钟前
从区间锁到行锁:一次高并发写入死锁治理实战
后端·sql
随风,奔跑1 小时前
Spring Cloud Alibaba(四)---Spring Cloud Gateway
后端·spring·gateway
用户8356290780511 小时前
Python 设置 PowerPoint 文档属性与页面参数
后端·python
Rust研习社1 小时前
Once、OnceCell、OnceLock:Rust 一次性初始化终极指南
后端·rust·编程语言
Rust研习社1 小时前
从入门到实践:Rust 异步编程完全指南
开发语言·后端·rust
GreenTea1 小时前
DeepSeek-V4 技术报告深度分析:基础研究创新全景
前端·人工智能·后端
用户8356290780511 小时前
使用 Python 自动管理 PowerPoint 幻灯片分节的方法
后端·python
逸风尊者2 小时前
XGBoost模型工程使用
java·后端·算法