什么是Thymeleaf
Thymeleaf是适用于Web和独立环境的现代服务器端Java模板引擎。
模板引擎
使用户界面与业务数据分离而产生的,它可以生成特定的文档,用于网站的模板引擎就会生成一个标准的html文档。
比如教室,在学生和老师到来之前,把桌椅讲台布置好,老师同学来了之后直接使用即可。
特点
动静分离:使用html通过一些特定标签语法代表其含义,但并未破坏html结构,即使无网络、不通过后端渲染也能在浏览器成功打开,方便界面的测试和修改。
传统的jsp模板引擎,本质上是将html文件修改后缀为.jsp,然后在这个文件中增加自己的语法、标签,执行时通过后台处理这个文件最终返回一个html页面。浏览器无法直接识别.jsp文件,需要借助网络(服务器)才能访问。
Thymeleaf用html做模板可以直接在浏览器中打开。开发者将Thymeleaf的语法通过html的标签属性来定义完成,这些标签属性不会影响html页面的完整性和显示,如果通过后台服务端访问页面服务端会寻找这些标签将服务端对应的数据替换到相应位置实现动态页面。
动态页面每次修改都需要重新启动程序、输入链接。但是如果界面设计人员通过静态页面设计样式,设计完成通过服务端访问即可达到目标UI的界面和应用,达到动静分离的效果。
开箱即用:直接套用模板实现JSTL、OGNL表达式的效果,避免套模板、改JSTL、改标签的困扰。同时开发人员也可以扩展和创建自定义的方言。
thymeleaf配置说明
# 是否允许页面缓存,在开发过程中需要确保页面是最新的所以需要禁用缓存
# 而在上线运营时,页面不常改动,为了减少服务端压力以及提升客户端响应速度会允许使用页面缓存
spring.thymeleaf.cache = false
# 确定页面的编码格式
spring.thymeleaf.encoding = UTF-8
# springboot默认模板引擎文件放在templates下
spring.thymeleaf.prefix = classpath:/templates/
常用标签
标签 | 作用 | 示例 |
---|---|---|
th:id | 替换id | <input th:id="${user.id}"> |
th:text | 文本替换 | <p th:text="${user.name}">Here is an example</p> |
th:utext | 支持html的文本替换 | <p th:utext="${htmlcontent}">content</p> |
th:object | 替换对象 | <div th:object="${user}"></div> |
th:value | 替换值 | <input th:value="${user.name}"> |
th:each | 迭代 | <tr th:each=“student:${user}”> |
th:href | 替换超链接 | <a th:href="@{index.html}">超链接 </a> |
th:src | 替换资源 | <script type=“text/javascript” th:src="@{index.js}"></script> |
链接表达式
引入thymeleaf模板引擎
<html xmlns:th="http://www.thymeleaf.org">
引入css
<link rel="stylesheet" th:href="@{index.css}">
引入JavaScript
<script type="text/javascript" th:src="@{index.js}"></script