【亲测免费】 Thymeleaf 入门指南及实战教程
项目介绍
Thymeleaf 是一款适用于现代服务器端 Java 环境的模板引擎,它特别适合用于Web和独立环境。Thymeleaf 的核心目标是让开发过程中使用的模板保持优雅和自然——即HTML可以直接在浏览器中显示,并且可以作为静态原型来增强团队协作效率。通过集成Spring框架、支持多种工具的整合以及允许自定义功能插件,Thymeleaf 成为了现代HTML5 JVM Web开发的理想选择,尽管它的能力远不止于此。
项目快速启动
要快速开始使用Thymeleaf,首先确保你的开发环境中已经安装了Java和Maven。接下来,创建一个简单的 Maven 项目,并加入Thymeleaf依赖:
<!-- pom.xml -->
<dependencies>
<dependency>
<groupId>org.thymeleaf</groupId>
<artifactId>thymeleaf-spring5</artifactId>
<version>3.1.2.RELEASE</version>
</dependency>
</dependencies>
然后,在资源目录(如src/main/resources/templates)下创建一个名为index.html的文件,添加基本的Thymeleaf语法:
<!DOCTYPE html>
<html xmlns:th="http://www.thymeleaf.org">
<head>
<title>Hello Thymeleaf!</title>
</head>
<body>
<h1 th:text="${'Hello ' + #strings.capitalize(#localdatetime.now().toString())}"></h1>
</body>
</html>
接着,在Spring MVC控制器中配置Thymeleaf视图:
@Controller
public class HelloWorldController {
@GetMapping("/")
public String welcome(Model model) {
model.addAttribute("greeting", "World");
return "index";
}
}
运行你的应用程序,访问 http://localhost:8080/,你会看到一个动态问候页面:“Hello [当前时间的小时和分钟]”。
应用案例和最佳实践
案例一:条件渲染
在Thymeleaf中,利用th:if和th:unless可以轻松实现条件渲染:
<p th:if="${user.isAdmin}">您是管理员。</p>
<p th:unless="${user.isAdmin}" th:text="${'欢迎,' + user.username}">默认欢迎语。</p>
最佳实践
- 使用Thymeleaf的标准命名惯例,增加代码可读性。
- 利用Thymeleaf的表达式对象(
#arrays,#messages, etc.)进行高效的数据处理。 - 避免在模板中放置过于复杂的逻辑,保持模板的“清洁”。
典型生态项目
Thymeleaf生态系统丰富,提供了许多插件和整合方案,例如:
-
Thymeleaf Extras Tiles2 - 提供Apache Tiles 2.x的集成,便于复杂的页面结构管理。
-
Thymeleaf Interactive Tutorial - 互动教程帮助开发者快速学习Thymeleaf。
-
Thymeleaf Eclipse Plugin - 专为Eclipse IDE设计的Thymeleaf集成插件,提升开发体验。
这些生态项目进一步强化了Thymeleaf在不同场景下的适用性和灵活性,使开发者能够更便捷地利用Thymeleaf进行高效的Web应用开发。
Kimi-K2.5Kimi K2.5 是一款开源的原生多模态智能体模型,它在 Kimi-K2-Base 的基础上,通过对约 15 万亿混合视觉和文本 tokens 进行持续预训练构建而成。该模型将视觉与语言理解、高级智能体能力、即时模式与思考模式,以及对话式与智能体范式无缝融合。Python00- QQwen3-Coder-Next2026年2月4日,正式发布的Qwen3-Coder-Next,一款专为编码智能体和本地开发场景设计的开源语言模型。Python00
xw-cli实现国产算力大模型零门槛部署,一键跑通 Qwen、GLM-4.7、Minimax-2.1、DeepSeek-OCR 等模型Go06
PaddleOCR-VL-1.5PaddleOCR-VL-1.5 是 PaddleOCR-VL 的新一代进阶模型,在 OmniDocBench v1.5 上实现了 94.5% 的全新 state-of-the-art 准确率。 为了严格评估模型在真实物理畸变下的鲁棒性——包括扫描伪影、倾斜、扭曲、屏幕拍摄和光照变化——我们提出了 Real5-OmniDocBench 基准测试集。实验结果表明,该增强模型在新构建的基准测试集上达到了 SOTA 性能。此外,我们通过整合印章识别和文本检测识别(text spotting)任务扩展了模型的能力,同时保持 0.9B 的超紧凑 VLM 规模,具备高效率特性。Python00
KuiklyUI基于KMP技术的高性能、全平台开发框架,具备统一代码库、极致易用性和动态灵活性。 Provide a high-performance, full-platform development framework with unified codebase, ultimate ease of use, and dynamic flexibility. 注意:本仓库为Github仓库镜像,PR或Issue请移步至Github发起,感谢支持!Kotlin08
VLOOKVLOOK™ 是优雅好用的 Typora/Markdown 主题包和增强插件。 VLOOK™ is an elegant and practical THEME PACKAGE × ENHANCEMENT PLUGIN for Typora/Markdown.Less00