先了解Thymeleaf是什么
1. Thymeleaf 简介
  Thymeleaf 是新⼀代 Java 模板引擎,与 Velocity、FreeMarker 等传统 Java 模板引擎不同,Thymeleaf ⽀持 HTML 原型,其⽂件后缀为“.html”,因此它可以直接被浏览器打开,如果你直接浏览器打开,此时浏览器会忽略未定义的 Thymeleaf 标签属性,展示thymeleaf 模板的静态⻚⾯(没有任何变化)效果;但是通过 Web 应⽤程序访问时,Thymeleaf 会动态地替换掉静态内容,使⻚⾯动态显示。
  简而言之,就是之前你的html页面的一个p标签显示的是“法外狂徒张三”,加上Thymeleaf后,通过Web 应⽤程序访问后就变成了,“隔壁老王”。

使用只需要在前端页面注意这个就行了,html标签里面加上: xmlns:th="http://www.thymeleaf.org

<html lang="en" xmlns:th="http://www.thymeleaf.org">
然后就可以使用了

然后举个例子

<h1 th:text="${'隔壁老王'}">法外狂徒张三</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 替换对象 <div th:object="${session.user}">
th:value 属性赋值 <input th:value = "${user.name}" />
th:with 变量赋值运算 <div th:with="isEvens = ${prodStat.count}%2 == 0"></div>
th:style 设置样式 <div th:style="'display:' + @{(${sitrue} ? 'none' : 'inline-block')} + ''"></div>
th:onclick 点击事件 <td th:onclick = "'getCollect()'"></td
th:each 属性赋值 <tr th:each = "user,userStat:${users}">
th:if 判断条件 <a th:if = "${userId == collect.userId}">
th:unless 和th:if判断相反,满足条件时不显示 <a th:href="@{/login} th:unless=${session.user != null}">Login</a> <!--如果用户已登录,则不显示登录按钮-->
th:href 链接地址 <a th:href="@{/login}" th:unless=${session.user != null}>Login</a>
th:switch 多路选择,配合th:case使用 <div th:switch="${user.role}">
th:fragment 模板布局,类似jsp的tag <div th:fragment="footer">&copy; 2013 Footer</div>
th:include 布局标签,替换内容到引入的文件 <head th:include="layout :: htmlhead" th:with="title='xx'"></head>
th:replace 布局标签,替换整个标签到引入的文件 <div th:replace="fragments/header :: title"></div>
th:selected select选择框选中 th:selected="(${xxx.id} == ${configObj.dd})"
th:src 图片类地址引入 <img class="img-responsive" alt="App Logo" th:src="@{/img/logo.png}" />
th:inline 定义js脚本可以使用变量 <script type="text/javascript" th:inline="javascript">
th:action 表单提交的地址 <form action="subscribe.html" th:action="@{/subscribe}">
th:remove 删除某个属性

<tr th:remove="all"> 1.all:删除包含标签和所有的孩子。2.body:不包含标记删除,但删除其所有的孩子。

3.tag:包含标记的删除,但不删除它的孩子。4.all-but-first:删除所有包含标签的孩子,除了第一个。5.none:什么也不做。这个值是有用的动态评估。

th:attr 设置标签属性,多个属性可以使用逗号分隔 比如 th:attr="src=@{/image/aa.jpg},title=#{logo}",此标签不太优雅,一般用的比较少。
引用Thymeleaf属性原文地址:

https://www.jianshu.com/p/f9ebd23e8da4

最新文章

  1. 51Nod-1136 欧拉函数
  2. 第一次接触OOM
  3. nginx 安装及代理配置。
  4. IOS开发-视频,音频,录音简单总结
  5. Mac下java编译乱码(适用于maven , ant)
  6. C++:向函数传递对象(对象、对象指针、对象引用)
  7. git reset and git checkout
  8. IO 流—&gt;&gt;&gt;补充
  9. ComboBox( 下拉列表框)
  10. 安卓开发之RecyclerView
  11. JBPM6教程
  12. Centos 7 静态学习IP建立
  13. Jenkins中集成Gcov代码覆盖率报告
  14. PAT1006
  15. UI设计基础知识和JavaScript
  16. 本地phpstudy时常停机连接失败,php.ini文件中9000端口问题
  17. 关于&lt;input type=&quot;date&quot;&gt;这种取值的问题 【原创】
  18. String字符串类总结
  19. 【转】浅析Java中的final关键字
  20. xlrd &amp; xlwd

热门文章

  1. 探索ABP基础架构-下
  2. 无线:PIN码
  3. 手把手教你使用Git管理你的软件代码
  4. 安装Suberversion[SVN]到CentOS(YUM)
  5. typescript 的安装和检测是否安装成功
  6. AntdVue使用
  7. vs 快速定位文件
  8. Navicat可视化MySQL数据库
  9. MySQL - 数据库设计步骤
  10. Python 3函数的参数冒号注释