Spring Boot中如何使用thymeleaf呢?

乔欣 SpringBoot 发布时间:2023-02-13 09:36:04 阅读数:836 1
下文笔者讲述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>
版权声明

本文仅代表作者观点,不代表本站立场。
本文系作者授权发表,未经许可,不得转载。

本文链接: https://www.Java265.com/JavaFramework/SpringBoot/202302/5774.html

最近发表

热门文章

好文推荐

Java265.com

https://www.java265.com

站长统计|粤ICP备14097017号-3

Powered By Java265.com信息维护小组

使用手机扫描二维码

关注我们看更多资讯

java爱好者