欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Java基礎(chǔ)總結(jié)之Thymeleaf詳解

 更新時間:2021年05月14日 09:20:37   作者:wangxu123445678  
Thymeleaf是一種現(xiàn)代的基于服務(wù)器端的Java模板引擎技術(shù),也是一個優(yōu)秀的面向Java的XML、XHTML、HTML5頁面模板,它具有豐富的標(biāo)簽語言、函數(shù)和表達(dá)式,在使用Spring Boot框架進(jìn)行頁面設(shè)計時,一般會選擇Thymeleaf模板,需要的朋友可以參考下

一、Thymeleaf語法

標(biāo)簽

在HTML頁面上使用Thymeleaf標(biāo)簽,Thymeleaf 標(biāo)簽?zāi)軌騽討B(tài)地替換掉靜態(tài)內(nèi)容,使頁面動態(tài)展示。為了大家更直觀的認(rèn)識Thymeleaf,下面展示一個在HTML文件中嵌入了Thymeleaf的頁面文件,示例代碼如下:

<!DOCTYPE html>
<html lang="en" xmlns:th="http://www.thymeleaf.org">
<head>
    <meta charset="UTF-8">
        <link rel="stylesheet" type="text/css" media="all"
        href="../../css/gtvg.css" rel="external nofollow"  th:href="@{/css/gtvg.css}" rel="external nofollow"  />
    <title>Title</title>
</head>
<body>
	<p th:text="${hello}">歡迎進(jìn)入Thymeleaf的學(xué)習(xí)</p>
</body>
</html>

thymelef常用標(biāo)簽

標(biāo)簽 說明
th:insert 布局標(biāo)簽,替換內(nèi)容到引入的文件
th:replace 頁面片段包含(類似JSP中的include標(biāo)簽)
th:each 元素遍歷(類似JSP中的c:forEach標(biāo)簽)
th:if 條件判斷,如果為真
th:unless 條件判斷,如果為假
th:switch 條件判斷,進(jìn)行選擇性匹配
th:case 條件判斷,進(jìn)行選擇性匹配
th:value 屬性值修改,指定標(biāo)簽屬性值
th:href 用于設(shè)定鏈接地址
th:src 用于設(shè)定鏈接地址
th:text 用于指定標(biāo)簽顯示的文本內(nèi)容

標(biāo)準(zhǔn)表達(dá)式

說明 表達(dá)式語法
變量表達(dá)式 ${…}
選擇變量表達(dá)式 *{…}
消息表達(dá)式 #{…}
鏈接URL表達(dá)式 @{…}
片段表達(dá)式 ~{…}

1.1 變量表達(dá)式${…}

主要用于獲取上下文中的變量值,示例代碼如下:

<p th:text="${title}">這是標(biāo)題</p>

Thymeleaf為變量所在域提供了一些內(nèi)置對象,具體如下所示

# ctx:上下文對象
# vars:上下文變量
# locale:上下文區(qū)域設(shè)置
# request:(僅限Web Context)HttpServletRequest對象
# response:(僅限Web Context)HttpServletResponse對象
# session:(僅限Web Context)HttpSession對象
# servletContext:(僅限Web Context)ServletContext對象

假設(shè)要在Thymeleaf模板引擎頁面中動態(tài)獲取當(dāng)前國家信息,可以使用
#locale內(nèi)置對象,示例代碼如下

The locale country is: <span th:text="${#locale.country}">US</span>

1.2 選擇變量表達(dá)式*{…}

和變量表達(dá)式用法類似,一般用于從被選定對象而不是上下文中獲取屬性值,如果沒有選定對象,則和變量表達(dá)式一樣,示例代碼如下

<div th:object="${book}">
<p>titile: <span th:text="*{title}">標(biāo)題</span>.</p>
</div>

*{title} 選擇變量表達(dá)式獲取當(dāng)前指定對象book的title屬性值。

1.3 消息表達(dá)式 #{…}

消息表達(dá)式#{…}主要用于Thymeleaf模板頁面國際化內(nèi)容的動態(tài)替換和展示,使用消息表達(dá)式#{…}進(jìn)行國際化設(shè)置時,還需要提供一些國際化配置文件。

1.4 鏈接表達(dá)式 @{…}

鏈接表達(dá)式@{…}一般用于頁面跳轉(zhuǎn)或者資源的引入,在Web開發(fā)中占據(jù)著非常重要的地位,并且使用也非常頻繁

<a th:href="@{http://localhost:8080/order/details(orderId=${o.id})}" rel="external nofollow" >view</a>
<a th:href="@{/order/details(orderId=${o.id},pid=${p.id})}" rel="external nofollow" >view</a>

鏈接表達(dá)式@{…}分別編寫了絕對鏈接地址和相對鏈接地址。

在有參表達(dá)式中,需要按照@{路徑(參數(shù)名稱=參數(shù)值,參數(shù)名稱=參數(shù)值…)}的形式編寫,同時該參數(shù)的值可以使用變量表達(dá)式來傳遞動態(tài)參數(shù)值

1.5 片段表達(dá)式 ~{…}

片段表達(dá)式~{…}用來標(biāo)記一個片段模板,并根據(jù)需要移動或傳遞給其他模板。其中,最常見的用法是使用th:insert或th:replace屬性插入片段

<div th:insert="~{thymeleafDemo::title}"></div>

thymeleafDemo為模板名稱,Thymeleaf會自動查找“/resources/templates/”目錄下的thymeleafDemo模板,title為片段名稱

二、基本使用

2.1 Thymeleaf模板基本配置

首先 在Spring Boot項(xiàng)目中使用Thymeleaf模板,首先必須保證引入Thymeleaf依賴

<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-thymeleaf</artifactId>
</dependency>

其次,在全局配置文件中配置Thymeleaf模板的一些參數(shù)。一般Web項(xiàng)目都會使用下列配置

spring.thymeleaf.cache = true #啟用模板緩存
spring.thymeleaf.encoding = UTF_8 #模板編碼
spring.thymeleaf.mode = HTML5 #應(yīng)用于模板的模板模式
spring.thymeleaf.prefix = classpath:/templates/ #指定模板頁面存放路徑
spring.thymeleaf.suffix = .html #指定模板頁面名稱的后綴

上述配置中:

spring.thymeleaf.cache表示是否開啟Thymeleaf模板緩存,默認(rèn)為true,在開發(fā)過程中通常會關(guān)閉緩存,保證項(xiàng)目調(diào)試過程中數(shù)據(jù)能夠及時響應(yīng);

spring.thymeleaf.prefix指定了Thymeleaf模板頁面的存放路徑,默認(rèn)為classpath:/templates/;

spring.thymeleaf.suffix指定了Thymeleaf模板頁面的名稱后綴,默認(rèn)為.html

到此這篇關(guān)于Java基礎(chǔ)總結(jié)之Thymeleaf模板的文章就介紹到這了,更多相關(guān)Java Thymeleaf模板內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

最新評論