先了解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\">
然后就可以使用了
然后举个例子
<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\">© 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 | 删除某个属性 |
|
th:attr | 设置标签属性,多个属性可以使用逗号分隔 | 比如 th:attr=\"src=@{/image/aa.jpg},title=#{logo}\",此标签不太优雅,一般用的比较少。 |
引用Thymeleaf属性原文地址:
https://www.jianshu.com/p/f9ebd23e8da4
创作不易,点一个赞再走
本文来自博客园,作者:Aons谦,转载请注明原文链接:https://www.cnblogs.com/Aons0812/p/16537582.html
来源:https://www.cnblogs.com/Aons0812/p/16537582.html
本站部分图文来源于网络,如有侵权请联系删除。