1. 程式人生 > >2.springboot之Thymeleaf語法詳解

2.springboot之Thymeleaf語法詳解

1.th:text

在頁面中輸出值

2.th:value

可以將一個值放入到 input 標籤的 value 中
3.判斷字串是否為空

Thymeleaf內建物件

注意語法:
1,呼叫內建物件一定要用#
2,大部分的內建物件都以 s 結尾 strings、numbers、dates
${#strings.isEmpty(key)}
判斷字串是否為空,如果為空返回 true,否則返回 false
${#strings.contains(msg,‘T’)}
判斷字串是否包含指定的子串,如果包含返回 true,否則返回 false
${#strings.startsWith(msg,‘a’)}
判斷當前字串是否以子串開頭,如果是返回 true,否則返回 false
${#strings.endsWith(msg,‘a’)}
判斷當前字串是否以子串結尾,如果是返回 true,否則返回 false
${#strings.length(msg)}
返回字串的長度
${#strings.indexOf(msg,‘h’)}
查詢子串的位置,並返回該子串的下標,如果沒找到則返回-1
${#strings.substring(msg,13)}
${#strings.substring(msg,13,15)}
擷取子串,使用者與 jdk String 類下 SubString 方法相同
${#strings.toUpperCase(msg)}
${#strings.toLowerCase(msg)}
字串轉大小寫。

3.2 日期格式化處理

${#dates.format(key)}
格式化日期,預設的以瀏覽器預設語言為格式化標準
${#dates.format(key,‘yyy/MM/dd’)}
按照自定義的格式做日期轉換
${#dates.year(key)}
${#dates.month(key)
${#dates.day(key)}
year:取年
Month:取月
Day:取日

3.3條件判斷

th:if

<span th:if="${sex} == '男'">
性別:男
</span>
<span th:if="${sex} == '女'">
性別:女
<
/span>

th:switch

<div th:switch="${id}">
<span th:case="1">ID 為 1</span>
<span th:case="2">ID 為 2</span>
<span th:case="3">ID 為 3</span>
</div>

迭代遍歷 th:each

<table border="1">
<tr>
<th>ID</th>
<th>Name</th>
<
th>Age</th> <th>Index</th> <th>Count</th> <th>Size</th> <th>Even</th> <th>Odd</th> <th>First</th> <th>lase</th> </tr> <tr th:each="u,var : ${list}"> <td th:text="${u.userid}"></td> <td th:text="${u.username}"></td> <td th:text="${u.userage}"></td> <td th:text="${var.index}"></td> <td th:text="${var.count}"></td> <td th:text="${var.size}"></td> <td th:text="${var.even}"></td> <td th:text="${var.odd}"></td> <td th:text="${var.first}"></td> <td th:text="${var.last}"></td> </tr> </table>

狀態變數屬性
1,index:當前迭代器的索引 從 0 開始
2,count:當前迭代物件的計數 從 1 開始
3,size:被迭代物件的長度
4,even/odd:布林值,當前迴圈是否是偶數/奇數 從 0 開始
5,first:布林值,當前迴圈的是否是第一條,如果是返回 true 否則返回 false
6,last:布林值,當前迴圈的是否是最後一條,如果是則返回 true 否則返回 false
th:each 迭代 Map

@RequestMapping("/show4")
public String showInfo4(Model model){
Map<String, Users> map = new HashMap<>();
map.put("u1", new Users(1,"張三",20));
map.put("u2", new Users(2,"李四",22));
map.put("u3", new Users(3,"王五",24));
model.addAttribute("map", map);
return "index4";

}
<table border="1">
<tr>
<th>ID</th>
<th>Name</th>
<th>Age</th>
</tr>
<tr th:each="maps : ${map}">
<td th:text="${maps}"></td>
</tr>
</table>
<th/>
<table border="1">
<tr>
<th>ID</th>
<th>Name</th>
<th>Age</th>
</tr>
<tr th:each="maps : ${map}">
<td th:each="entry:${maps}"
th:text="${entry.value.userid}" ></td>
<td th:each="entry:${maps}"
th:text="${entry.value.username}"></td>
<td th:each="entry:${maps}"
th:text="${entry.value.userage}"></td>
</tr>
</table>

域物件操作
1.HttpServletRequest
request.setAttribute(“req”, “HttpServletRequest”);
Request:

<span th:text="${#httpServletRequest.getAttribute('req')}"></span><br/>

2.HttpSession
request.getSession().setAttribute(“sess”, “HttpSession”);

Session:<span th:text="${session.sess}"></span><br/>

3.ServletContext
request.getSession().getServletContext().setAttribute(“app”,“Application”);

Application:<span th:text="${application.app}"></span>

URL 型別

絕對路徑

<a th:href="@{http://www.baidu.com}">絕對路徑</a><br/>

相對路徑
相對於當前專案的根

<a th:href="@{/show}">相對路徑</a>

相對於伺服器路徑的根

<a th:href="@{~/project2/resourcename}">相對於伺服器的根</a>

在 url 中實現引數傳遞

<a th:href="@{/show(id=1,name=zhagnsan)}">相對路徑-傳參</a>

在 url 中通過 restful 風格進行引數傳遞

<a th:href="@{/path/{id}/show(id=1,name=zhagnsan)}"> 相 對 路 徑 - 傳 參
-restful</a>