Spring Boot中如何使用thymeleaf呢?
下文笔者讲述SpringBoot中使用thymeleaf的方法分享,如下所示
thymeleaf简介
thymeleaf: 是一个模板引擎 spring4.0框架中曾经极力推荐大家使用thymeleaf作为前端模版引擎 thymeleaf是一个可以和Velocity、FreeMarker引擎想匹配,她可以完美的匹配JSP thymeleaf具有以下特点: Thymeleaf的运行无需特定网络,可以很好的开发前端页面(因为她是所见即所得的效果) 只需在html页面加入相应的标签即可,Thymeleaf引擎可以很好的解析标签中的值 Thymeleaf: 开箱即用 它提供标准和spring标准两种方言 可直接套用模板实现JSTL、 OGNL表达式效果
Thymeleaf表达式的语法
变量表达式 选择或星号表达式 文字国际化表达式 URL表达式
变量表达式
变量表达式: 即OGNL表达式或Spring EL表达式 ${session.user.name}: 以HTML标签的一个属性来表示 <span th:text="${user.author.name}"> <li th:each="user : ${users}">
选择(星号)表达式
选择表达式很像变量表达式 它们用一个预先选择的对象来代替上下文变量容器(map)来执行 如下: *{user.name} 被指定的object由th:object属性定义: <div th:object="${user}"> ... <span th:text="*{title}">...</span> ... </div>
文字国际化表达式
文字国际化表达式 允许我们从一个外部文件获取区域文字信息(.properties) 用Key索引Value,其目的实现网页的多语言 #{main.title} #{message.entrycreated(${entryId})} 可以在模板文件中找到这样的表达式代码: <table> ... <th th:text="#{header.address.city}">...</th> <th th:text="#{header.address.country}">...</th> ... </table>
URL表达式
URL表达式: 把一个有用的上下文或回话信息添加到URL 这个过程经常被叫做URL重写 @{/order/list} URL还可以设置参数 @{/order/details(id=${orderId})} 相对路径 @{../documents/report} form表单中的url表达式 <form th:action="@{/createOrder}"> <a href="main.html" th:href="@{/main}">
变量表达式和星号表达的区别说明
<div th:object="${session.user}"> <p>Name: <span th:text="*{firstName}">Sebastian</span>.</p> <p>Surname: <span th:text="*{lastName}">Pepper</span>.</p> <p>Nationality: <span th:text="*{nationality}">Saturn</span>.</p> </div> 等同于: <div th:object="${session.user}"> <p>Name: <span th:text="${session.user.firstName}">Sebastian</span>.</p> <p>Surname: <span th:text="${session.user.lastName}">Pepper</span>.</p> <p>Nationality: <span th:text="${session.user.nationality}">Saturn</span>.</p> </div> 美元符号和星号语法可以混合使用 <div th:object="${session.user}"> <p>Name: <span th:text="*{firstName}">Sebastian</span>.</p> <p>Surname: <span th:text="${session.user.lastName}">Pepper</span>.</p> <p>Nationality: <span th:text="*{nationality}">Saturn</span>.</p> </div>
表达式支持的语法
字面(Literals) 文本文字(Text literals): 'one text', 'Another one!',… 数字文本(Number literals): 0, 34, 3.0, 12.3,… 布尔文本(Boolean literals): true, false 空(Null literal): null 文字标记(Literal tokens): one, sometext, main,… 文本操作(Text operations) 字符串连接(String concatenation): + 文本替换(Literal substitutions): |The name is ${name}| 算术运算(Arithmetic operations) 二元运算符(Binary operators): +, -, *, /, % 减号(单目运算符)Minus sign (unary operator): - 布尔操作(Boolean operations) 二元运算符(Binary operators):and, or 布尔否定(一元运算符)Boolean negation (unary operator):!, not 比较和等价(Comparisons and equality) 比较(Comparators): >, <, >=, <= (gt, lt, ge, le) 等值运算符(Equality operators):==, != (eq, ne) 条件运算符(Conditional operators) If-then: (if) ? (then) If-then-else: (if) ? (then) : (else) Default: (value) ?: (defaultvalue) 所有这些特征可以被组合并嵌套: 'User is of type ' + (${user.isAdmin()} ? 'Administrator' : (${user.type} ?: 'Unknown'))
th标签
一个标签内可以包含多个th:x属性 其生效的优先级顺序为: include, each, if/unless/switch/case, with, attr/attrprepend/attrappend, value/href, src, etc, text/utext, fragment, remove
赋值、字符串拼接
<p th:text="${collect.description}">description</p> <span th:text="'Welcome to our application, ' + ${user.name} + '!'"> 字符串拼接还有另外一种简洁的写法 <span th:text="|Welcome to our application, ${user.name}!|">
条件判断 If/Unless
Thymeleaf中 使用th:if和th:unless属性进行条件判断 例: <a>标签只有在th:if中条件成立时才显示 <a th:if="${myself=='yes'}" > </i> </a> <a th:unless=${session.user != null} th:href="@{/login}" >Login</a> th:unless于th:if恰好相反 只有表达式中的条件不成立 才会显示其内容 也可使用 (if) ? (then) : (else) 三元表达式的形式显示内容
for 循环
<tr th:each="collect,iterStat : ${collects}"> <th scope="row" th:text="${collect.id}">1</th> <td > <img th:src="${collect.webLogo}"/> </td> <td th:text="${collect.url}">Mark</td> <td th:text="${collect.title}">Otto</td> <td th:text="${collect.description}">@mdo</td> <td th:text="${terStat.index}">index</td> </tr> iterStat状态--迭代器变量属性: index:当前迭代对象的index(从0开始计算) count: 当前迭代对象的index(从1开始计算) size:被迭代对象的大小 current:当前迭代变量 even/odd:布尔值,当前循环是否是偶数/奇数(从0开始计算) first:布尔值,当前循环是否是第一个 last:布尔值,当前循环是否是最后一个
URL
URL 在Web应用模板中占据着十分重要的地位 需要特别注意的是Thymeleaf对于URL的处理是通过语法@{…}来处理的 当需要Thymeleaf对URL进行渲染 务必使用th:href,th:src等属性 例: <!-- Will produce 'http://localhost:8080/standard/unread' (plus rewriting) --> <a th:href="@{/standard/{type}(type=${type})}">view</a> <!-- Will produce '/gtvg/order/3/details' (plus rewriting) --> <a href="details.html" th:href="@{/order/{orderId}/details(orderId=${o.id})}">view</a>
设置背景
<div th:style="'background:url(' + @{/<path-to-image>} + ');'"></div> //根据属性值改变背景 <div class="media-object resource-card-image" th:style="'background:url(' + @{(${collect.webLogo}=='' ? 'img/favicon.png' : ${collect.webLogo})} + ')'" ></div>
内联js
内联文本: [[…]]内联文本的表示方式 使用时,需先使用th:inline=”text/javascript/none”激活 th:inline可以在父级标签内使用 作为body的标签 <script th:inline="javascript"> /*<![CDATA[*/ ... var username = /*[[${sesion.user.name}]]*/ 'Sebastian'; var size = /*[[${size}]]*/ 0; ... /*]]>*/ </script> //js附加代码 /*[+ var msg = 'This is a working application'; +]*/ //js移除代码 /*[- */ var msg = 'This is a non-working template'; /* -]*/
内嵌变量
Thymeleaf提供一系列Utility对象(内置于Context中) 可使用#直接访问 dates : java.util.Date的功能方法类。 calendars : 类似#dates,面向java.util.Calendar numbers : 格式化数字的功能方法类 strings : 字符串对象的功能类,contains,startWiths,prepending/appending等等。 objects: 对objects的功能类操作。 bools: 对布尔值求值的功能方法。 arrays:对数组的功能类方法。 lists: 对lists功能类方法 sets maps
Thymeleaf之dates访问
/* * Format date with the specified pattern * Also works with arrays, lists or sets */ ${#dates.format(date, 'dd/MMM/yyyy HH:mm')} ${#dates.arrayFormat(datesArray, 'dd/MMM/yyyy HH:mm')} ${#dates.listFormat(datesList, 'dd/MMM/yyyy HH:mm')} ${#dates.setFormat(datesSet, 'dd/MMM/yyyy HH:mm')} /* * Create a date (java.util.Date) object for the current date and time */ ${#dates.createNow()} /* * Create a date (java.util.Date) object for the current date (time set to 00:00) */ ${#dates.createToday()}
strings
/* * Check whether a String is empty (or null). Performs a trim() operation before check * Also works with arrays, lists or sets */ ${#strings.isEmpty(name)} ${#strings.arrayIsEmpty(nameArr)} ${#strings.listIsEmpty(nameList)} ${#strings.setIsEmpty(nameSet)} /* * Check whether a String starts or ends with a fragment * Also works with arrays, lists or sets */ ${#strings.startsWith(name,'Don')} // also array*, list* and set* ${#strings.endsWith(name,endingFragment)} // also array*, list* and set* /* * Compute length * Also works with arrays, lists or sets */ ${#strings.length(str)} /* * Null-safe comparison and concatenation */ ${#strings.equals(str)} ${#strings.equalsIgnoreCase(str)} ${#strings.concat(str)} ${#strings.concatreplaceNulls(str)} /* * Random */ ${#strings.randomAlphanumeric(count)}
thymeleaf布局
<footer th:fragment="copy"> © 2023 </footer> 在页面任何地方引入 <body> <div th:include="footer :: copy"></div> <div th:replace="footer :: copy"></div> </body> th:include 和 th:replace区别,include只是加载,replace是替换 返回HTML信息: <body> <div> © 2023</div> <footer>© 2023 </footer> </body>
版权声明
本文仅代表作者观点,不代表本站立场。
本文系作者授权发表,未经许可,不得转载。