thymeleaf中 if 条件判断范例

本文介绍了Thymeleaf在Spring Boot应用中进行条件判断的使用方法,包括单一条件的gt、ge、eq、lt、le、ne比较操作符,以及多条件的&&、and、||、or组合判断。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

单一条件判断:

gt:great than(大于)>

<div th:if="${foo gt 2}"></div> <!--表示:如果 foo > 2 -->

ge:great equal(大于等于)>=

<div th:if="${foo ge 2}"></div> <!--表示:如果 foo >= 2 -->

eq:equal(等于)==

<div th:if="${foo eq 2}"></div> <!--表示:如果 foo == 2 -->

lt:less than(小于)<

<div th:if="${foo lt 2}"></div> <!--表示:如果 foo < 2 -->

le:less equal(小于等于)<=

<div th:if="${foo le 2}"></div> <!--表示:如果 foo <= 2 -->

ne:not equal(不等于)!=

<div th:if="${foo ne 2}"></div> <!--表示:如果 foo != 2 -->



多条件判断:

&& 或 and: 表示并且

<div th:if="${foo gt 2 && foo lt 8}"></div><div th:if="(${foo gt 2}) and ${foo lt 2}"></div> <!-- 表示:如果 foo > 2 且 foo < 8 -->

|| 或 or : 表示或者

<div th:if="${foo gt 2 || foo lt 8}"></div><div th:if="(${foo gt 2}) or ${foo lt 8}"></div>  <!-- 表示:如果 foo > 2 或 foo < 8-->
### Thymeleaf 中 `if` 条件语句的使用 在 Thymeleaf 模板引擎中,可以利用 `th:if` 属性来实现条件判断逻辑。当表达式的计算结果为真时,该元素及其内部的内容才会被渲染到最终页面。 #### 基本用法 对于简单的布尔表达式可以直接写入: ```html <div th:if="${isAdmin}"> Only visible to administrators. </div> ``` 这里 `${isAdmin}` 是一个布尔类型的变量,如果它的值为 true,则上述 div 将会被显示;反之则不会出现在 HTML 文档里[^1]。 #### 复合条件 支持通过 && 和 || 运算符组合多个条件来进行更复杂的判定: ```html <!-- 当 user 不为空且其 role 字段等于 'admin' 时 --> <p th:if="${user != null and user.role == 'admin'}">Welcome, Administrator!</p> <!-- 至少满足其中一个条件即可 --> <span th:if="${user.age >= 18 or user.hasPermission}">Adult content.</span> ``` #### 结合 else 的效果 (th:unless) 虽然 Thymeleaf 并未提供直接的 `else` 关键字,但是可以通过 `th:unless` 达成类似目的。它的工作方式正好相反于 `th:if` —— 即只有当给定条件不成立的时候才呈现相应部分: ```html <h2 th:if="${isLoggedIn()}">Logged In User Area</h2> <h2 th:unless="${isLoggedIn()}">Guest Visitor Section</h2> ``` 此外,在某些情况下也可以考虑采用三元运算符作为替代方案之一: ```html <p>Welcome back, <span th:text="${user.name != null}? ${user.name} : 'Guest'"></span>! </p> ``` 此例子展示了如何优雅处理存在与否的情况而不必显式编写完整的 if-then-else 结构[^2]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值