Thymeleaf是什么?该如何使用。

先了解Thymeleaf是什么

1. Thymeleaf 简介

Thymeleaf 是新⼀代 Java 模板引擎,与 Velocity、FreeMarker 等传统 Java 模板引擎不同,Thymeleaf ⽀持 HTML 原型,其⽂件后缀为”.html”,因此它可以直接被浏览器打开,如果你直接浏览器打开,此时浏览器会忽略未定义的 Thymeleaf 标签属性,展示thymeleaf 模板的 静态⻚⾯(没有任何变化)效果;但是通过 Web 应⽤程序访问时,Thymeleaf 会动态地替换掉静态内容,使⻚⾯动态显示。

简而言之,就是之前你的html页面的一个p标签显示的是”法外狂徒张三”,加上Thymeleaf后,通过Web 应⽤程序访问后就变成了,”隔壁老王”。

使用只需要在前端页面注意这个就行了(声明命名空间,非必要,不写idea会爆红,但是不影响使用),html标签里面加上: xmlns:th=”http://www.thymeleaf.org

<html lang="en" xmlns:th="http://www.thymeleaf.org">
&#x7136;&#x540E;&#x5C31;&#x53EF;&#x4EE5;&#x4F7F;&#x7528;&#x4E86;</html>

然后举个例子

<h1 th:text="${'&#x9694;&#x58C1;&#x8001;&#x738B;'}">&#x6CD5;&#x5916;&#x72C2;&#x5F92;&#x5F20;&#x4E09;</h1>

‘隔壁老王’ 这个地方可以使用占位符,我这样写比较直观

2.Thymeleafi 简单表达式:

  • 变量表达式:${….}
  • 选变量表达式:*{….}
  • 消息表达式:#{….}
  • 链接网址表达式:@{….}
  • 片段表达式:~{….}

我使用的是 IntelliJ IDEA 2021.1 (Ultimate Edition)自己就有这个插件。基于manven的,所以你们该导包导包。

<!--thymeleaf依赖-->
<dependency>
       <groupid>org.thymeleaf</groupid>
       <artifactid>thymeleaf</artifactid>
       <version>3.0.7.RELEASE</version>
 </dependency>

3.th 属性

标签属性 功能描述 示例 th:id 替换id <input th:id="'xxx' + ${collect.id}">

th:text 文本替换 <p th:text="${collect.description}">description</p>

th:utext 支持html的文本替换 <p th:utext="${htmlcontent}">content</p>

th:object 替换对象

th:value 属性赋值 <input th:value="${user.name}">

th:with 变量赋值运算

th:style 设置样式

th:onclick 点击事件 <td th:onclick="'getCollect()'"><p class="node-read-div2p"> th:each &#x5C5E;&#x6027;&#x8D4B;&#x503C; </p><code><tr th:each="user,userStat:${users}"></tr></code><p class="node-read-div2p"> th:if &#x5224;&#x65AD;&#x6761;&#x4EF6; </p><code></code><p class="node-read-div2p"> th:unless &#x548C;th:if&#x5224;&#x65AD;&#x76F8;&#x53CD;&#xFF0C;&#x6EE1;&#x8DB3;&#x6761;&#x4EF6;&#x65F6;&#x4E0D;&#x663E;&#x793A; </p><code><a th:href="@{/login} th:unless=${session.user != null}">Login</a> <!--如果用户已登录,则不显示登录按钮--></code><p class="node-read-div2p"> th:href &#x94FE;&#x63A5;&#x5730;&#x5740; </p><code><a th:href="@{/login}" th:unless="${session.user" !="null}">Login</a></code><p class="node-read-div2p"> th:switch &#x591A;&#x8DEF;&#x9009;&#x62E9;&#xFF0C;&#x914D;&#x5408;th:case&#x4F7F;&#x7528; </p><code></code><p class="node-read-div2p"> th:fragment &#x6A21;&#x677F;&#x5E03;&#x5C40;&#xFF0C;&#x7C7B;&#x4F3C;jsp&#x7684;tag </p><code><div th:fragment="footer">&#xA9; 2013 Footer</div></code><p class="node-read-div2p"> th:include &#x5E03;&#x5C40;&#x6807;&#x7B7E;&#xFF0C;&#x66FF;&#x6362;&#x5185;&#x5BB9;&#x5230;&#x5F15;&#x5165;&#x7684;&#x6587;&#x4EF6; </p><code><head th:include="layout :: htmlhead" th:with="title='xx'"></head></code><p class="node-read-div2p"> th:replace &#x5E03;&#x5C40;&#x6807;&#x7B7E;&#xFF0C;&#x66FF;&#x6362;&#x6574;&#x4E2A;&#x6807;&#x7B7E;&#x5230;&#x5F15;&#x5165;&#x7684;&#x6587;&#x4EF6; </p><code></code><p class="node-read-div2p"> th:selected select&#x9009;&#x62E9;&#x6846;&#x9009;&#x4E2D; </p><code>th:selected="(${xxx.id} == ${configObj.dd})"</code><p class="node-read-div2p"> th:src &#x56FE;&#x7247;&#x7C7B;&#x5730;&#x5740;&#x5F15;&#x5165; </p><code><img class="img-responsive" alt="App Logo" th:src="@{/img/logo.png}"></code><p class="node-read-div2p"> th:inline &#x5B9A;&#x4E49;js&#x811A;&#x672C;&#x53EF;&#x4EE5;&#x4F7F;&#x7528;&#x53D8;&#x91CF; </p><code><script type="text/javascript" th:inline="javascript"></code><p class="node-read-div2p"> th:action 表单提交的地址 </p><code><form action="subscribe.html" th:action="@{/subscribe}"></code><p class="node-read-div2p"> th:remove 删除某个属性</p><p><code><tr th:remove="all"> 1.all:删除包含标签和所有的孩子。2.body:不包含标记删除,但删除其所有的孩子。</code></p><p><code>3.tag:包含标记的删除,但不删除它的孩子。4.all-but-first:删除所有包含标签的孩子,除了第一个。5.none:什么也不做。这个值是有用的动态评估。</code></p><p class="node-read-div2p">th:attr 设置标签属性,多个属性可以使用逗号分隔 </p><code>比如 th:attr="src=@{/image/aa.jpg},title=#{logo}",此标签不太优雅,一般用的比较少。</code><p class="node-read-div2p">引用Thymeleaf<em id="__mceDel">属性原文地址:</em></p><p><em id="__mceDel"><a href="https://www.jianshu.com/p/f9ebd23e8da4" rel="noopener">https://www.jianshu.com/p/f9ebd23e8da4</a></em></p><p></p><p>创作不易,点一个赞再走<img src="https://img2022.cnblogs.com/blog/2296765/202207/2296765-20220731225112039-1537212464.png"><img src="https://img2022.cnblogs.com/blog/2296765/202207/2296765-20220731225116346-506661348.png"><img src="https://img2022.cnblogs.com/blog/2296765/202207/2296765-20220731225119890-1257236905.png"><img src="https://img2022.cnblogs.com/blog/2296765/202207/2296765-20220731225121617-2083093961.png"><img src="https://img2022.cnblogs.com/blog/2296765/202207/2296765-20220731225123325-1682658679.png"></p><p></p></div></div></script></code></td>

Original: https://www.cnblogs.com/Aons0812/p/16537582.html
Author: Aons谦
Title: Thymeleaf是什么?该如何使用。

原创文章受到原创版权保护。转载请注明出处:https://www.johngo689.com/643822/

转载文章受原作者版权保护。转载请注明原作者出处!

(0)

大家都在看

亲爱的 Coder【最近整理,可免费获取】👉 最新必读书单  | 👏 面试题下载  | 🌎 免费的AI知识星球