news 2026/5/1 11:11:29

Thymeleaf 语法

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Thymeleaf 语法
一、基础准备
  1. 引入 Thymeleaf在 HTML 页面的<html>标签中添加命名空间,让 IDE 识别 Thymeleaf 语法并提供提示:
    <html lang="zh-CN" xmlns:th="http://www.thymeleaf.org">
  2. 核心依赖(Maven)若使用 Spring Boot,只需引入 starter 依赖即可:

    xml

    <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-thymeleaf</artifactId> </dependency>
二、核心语法分类
1. 变量表达式(${})
  • 作用:获取后端传递到页面的变量值,是最常用的语法。
  • 语法th:text="${变量名}"
  • 示例:后端(Controller):
    @GetMapping("/user") public String getUser(Model model) { User user = new User("张三", 20); model.addAttribute("user", user); model.addAttribute("msg", "欢迎使用Thymeleaf"); return "user"; }
    前端页面:

    html

    预览

    <!-- 直接输出普通变量 --> <div th:text="${msg}">默认显示内容</div> <!-- 输出对象属性(支持点语法/方括号语法) --> <div th:text="${user.name}">默认姓名</div> <div th:text="${user['age']}">默认年龄</div>
  • 说明th:text会替换标签内的文本内容;若变量为 null,标签内默认内容会显示(开发时可用于占位)。
2. 选择变量表达式(*{})
  • 作用:基于已选择的对象(th:object)简化属性访问,避免重复写对象名。
  • 语法:先通过th:object指定对象,再用*{}访问属性。
  • 示例
    <div th:object="${user}"> <p th:text="*{name}">姓名</p> <p th:text="*{age}">年龄</p> </div>
  • 等价写法*{name}等价于${user.name},适合对象属性较多的场景。
3. 消息表达式(#{})
  • 作用:读取国际化配置文件(.properties)中的文本,实现多语言。
  • 语法th:text="#{配置项key}"
  • 示例:国际化文件(messages_zh_CN.properties):

    properties

    welcome=欢迎访问 user.name=用户名
    页面使用:
    <div th:text="#{welcome}">默认欢迎语</div> <label th:text="#{user.name}">姓名</label>
4. 链接表达式(@{/})
  • 作用:生成绝对路径 / 相对路径,自动拼接上下文路径(避免硬编码)。
  • 语法
    • 无参数:th:href="@{/路径}"
    • 带参数:th:href="@{/路径(参数1=值1,参数2=值2)}"
  • 示例
    <!-- 普通链接 --> <a th:href="@{/home}">首页</a> <!-- 带参数链接 --> <a th:href="@{/user/detail(id=1,type=normal)}">用户详情</a> <!-- 静态资源(CSS/JS) --> <link th:href="@{/css/style.css}" rel="stylesheet"> <script th:src="@{/js/index.js}"></script>
5. 片段表达式(~{})
  • 作用:复用页面片段(如页眉、页脚、侧边栏),减少代码冗余。
  • 核心标签
    • th:fragment:定义片段
    • th:insert/th:replace/th:include:引入片段(三者区别见下表)
标签作用特点
th:insert插入片段到当前标签内保留当前标签,片段作为子元素
th:replace用片段替换当前标签不保留当前标签,直接替换
th:include插入片段的内容到当前标签仅保留片段文本,已过时
  • 示例:定义片段(fragments/header.html):
    <div th:fragment="header"> <h1>网站头部</h1> <nav>导航栏</nav> </div>
    引入片段:
    <!-- 插入片段(保留当前div标签) --> <div th:insert="~{fragments/header :: header}"></div> <!-- 替换片段(当前div被片段替换) --> <div th:replace="~{fragments/header :: header}"></div> <!-- 简写(省略~{}) --> <div th:replace="fragments/header :: header"></div>
三、常用属性
1. 文本操作
属性作用示例
th:text替换标签内文本(转义 HTML)<p th:text="${msg}">默认值</p>
th:utext替换标签内文本(不转义 HTML)<p th:utext="${htmlMsg}">默认值</p>
2. 条件判断
  • th:if:条件为 true 时显示标签
  • th:unless:条件为 false 时显示标签(与 th:if 相反)
  • th:switch/th:case:多分支判断(类似 Java 的 switch)
  • 示例

    html

    预览

    <!-- 简单条件 --> <div th:if="${user.age >= 18}">成年</div> <div th:unless="${user.age >= 18}">未成年</div> <!-- 多分支 --> <div th:switch="${user.type}"> <p th:case="1">普通用户</p> <p th:case="2">VIP用户</p> <p th:case="*">未知用户</p> <!-- 默认分支 --> </div>
3. 循环遍历
  • th:each:遍历集合(List/Map/ 数组),语法:th:each="元素, 状态变量 : ${集合}"
  • 状态变量常用属性
    • index:索引(从 0 开始)
    • count:计数(从 1 开始)
    • size:集合大小
    • even/odd:是否偶数 / 奇数行
    • first/last:是否第一个 / 最后一个元素
  • 示例
    <!-- 遍历List --> <ul> <li th:each="u, stat : ${userList}" th:text="${u.name} + ' - ' + stat.count" th:class="${stat.odd} ? 'odd-row' : 'even-row'"> 默认内容 </li> </ul> <!-- 遍历Map --> <div th:each="entry : ${map}"> 键:<span th:text="${entry.key}"></span> 值:<span th:text="${entry.value}"></span> </div>
4. 动态属性
  • th:attr:设置任意 HTML 属性
  • 简写属性(更常用):th:id/th:class/th:src/th:href/th:value
  • 示例
    <!-- 动态设置id和class --> <div th:id="'user-' + ${user.id}" th:class="${user.status} ? 'active' : 'disable'"></div> <!-- 动态设置输入框值 --> <input type="text" th:value="${user.name}"> <!-- 动态设置checked --> <input type="checkbox" th:checked="${user.agree}">
5. 内联表达式
  • 作用:在 HTML 文本 / JS 中直接使用 Thymeleaf 表达式,无需标签属性。
  • 语法
    • 文本内联:[[${变量}]](转义 HTML)、[(${变量})](不转义 HTML)
    • JS 内联:在<script>标签中加th:inline="javascript",然后用/*[[${变量}]]*/
  • 示例
    <!-- 文本内联 --> <p>Hello, [[${user.name}]]!</p> <!-- JS内联 --> <script th:inline="javascript"> var userName = /*[[${user.name}]]*/ '默认值'; var userAge = /*[[${user.age}]]*/ 0; console.log(userName, userAge); </script>
四、常用工具类

Thymeleaf 提供内置工具类,可通过#工具类名调用方法,常用如下:

工具类作用示例
#strings字符串操作${#strings.isEmpty(msg)}${#strings.toUpperCase(name)}
#numbers数字格式化${#numbers.formatDecimal(price, 0, 2)}(保留 2 位小数)
#dates日期格式化${#dates.format(createTime, 'yyyy-MM-dd HH:mm:ss')}
#lists集合操作${#lists.isEmpty(userList)}${#lists.size(userList)}
#objects对象判断${#objects.nullSafe(user.age, 0)}(null 时返回默认值 0)

示例:

<!-- 字符串非空判断 --> <div th:if="${#strings.isNotEmpty(msg)}"> 消息:<span th:text="${msg}"></span> </div> <!-- 日期格式化 --> <div th:text="${#dates.format(user.createTime, 'yyyy-MM-dd')}"></div> <!-- 数字保留2位小数 --> <div th:text="${#numbers.formatDecimal(user.balance, 0, 2)}"></div>

总结

  1. 核心表达式${}(变量)、*{}(选择变量)、#{}(国际化)@{}(链接)、~{}(片段)是 Thymeleaf 最基础也是最核心的语法,需熟练掌握。
  2. 常用功能:条件判断(th:if/th:switch)、循环遍历(th:each)、动态属性(th:class/th:value)是页面开发中高频使用的功能,结合工具类可提升开发效率。
  3. 代码复用:通过th:fragment+th:insert/replace实现页面片段复用,是减少冗余代码的关键技巧。
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/1 9:04:23

如何轻松实现碧蓝航线全皮肤解锁:Perseus完整配置指南

如何轻松实现碧蓝航线全皮肤解锁&#xff1a;Perseus完整配置指南 【免费下载链接】Perseus Azur Lane scripts patcher. 项目地址: https://gitcode.com/gh_mirrors/pers/Perseus Perseus是一款专为碧蓝航线设计的开源补丁工具&#xff0c;能够帮助玩家解锁游戏内所有皮…

作者头像 李华
网站建设 2026/4/23 13:42:16

解锁安卓应用安装新姿势:告别XAPK格式困扰的转换工具详解

解锁安卓应用安装新姿势&#xff1a;告别XAPK格式困扰的转换工具详解 【免费下载链接】xapk-to-apk A simple standalone python script that converts .xapk file into a normal universal .apk file 项目地址: https://gitcode.com/gh_mirrors/xa/xapk-to-apk 你是否遇…

作者头像 李华
网站建设 2026/5/1 7:23:43

3步搞定Steam清单工具:高效攻略助你轻松掌握游戏文件管理

3步搞定Steam清单工具&#xff1a;高效攻略助你轻松掌握游戏文件管理 【免费下载链接】Onekey Onekey Steam Depot Manifest Downloader 项目地址: https://gitcode.com/gh_mirrors/one/Onekey Steam清单获取是游戏玩家和开发者必备技能&#xff0c;Onekey作为一款专业的…

作者头像 李华
网站建设 2026/5/1 7:24:11

Z-Image-Turbo负向提示词库推荐:提升图像质量的必备清单

Z-Image-Turbo负向提示词库推荐&#xff1a;提升图像质量的必备清单 1. 为什么负向提示词比你想象中更重要 很多人刚用Z-Image-Turbo时&#xff0c;会把全部精力放在正向提示词上——怎么描述得更美、更具体、更有画面感。这当然重要&#xff0c;但真正拉开图像质量差距的&am…

作者头像 李华