其他分享
首页 > 其他分享> > SpringBoot第十篇:thymeleaf详解

SpringBoot第十篇:thymeleaf详解

作者:互联网

作者:追梦1819
原文:https://www.cnblogs.com/yanfei1819/p/10931435.html
版权声明:本文为博主原创文章,转载请附上博文链接!

引言

  SpringBoot 对 Web 的支持,官方推荐的是模板引擎 thymelaf。本章中,作者原意是直接讲解 SpringBoot 与 Thymelaf 的集成。但是在示例完成时,发现集成并不难。核心关注点应该是 Thymelaf 模板引擎本身的用法。故本章将其单独提出来讲解。集成部分待下一章详解。


简介

  Thymeleaf 是一款用于渲染XML/XHTML/HTML5内容的模板引擎。类似JSP,Velocity,FreeMaker等,它也可以轻易的与Spring MVC等Web框架进行集成作为Web应用的模板引擎。与其它模板引擎相比,Thymeleaf最大的特点是能够直接在浏览器中打开并正确显示模板页面,而不需要启动整个Web应用。在开发团队中实现更强大的协调作用。


功能特性

标准表达式语法

1、 ${...} 变量表达式,Variable Expressions

变量表达式可使用 thymleaf 的内置对象和内置方法。例如:

<p>Today is: <span th:text="${today}">13 february 2011</span>.</p>

2、@{...} 链接表达式,Link URL Expressions

用于静态资源的引用,form表单的请求等链接。例如:

无参:@{/xxx}

有参:@{/xxx(k1=v1,k2=v2)} 对应url结构:xxx?k1=v1&k2=v2

引入本地资源:@{/项目本地的资源路径}

引入外部资源:@{/webjars/资源在jar包中的路径}

3、#{...} 消息表达式,Message Expressions

信息表达式通常用于国际化。

4、~{...} 代码块表达式,Fragment Expressions

  代码表达式主要用来页面布局的,支持两种语法结构:

注意:

  1. templatename:模版名,Thymeleaf会根据模版名解析完整路径:/resources/templates/templatename.html,要注意文件的路径;
  2. fragmentname:片段名,Thymeleaf通过th:fragment声明定义代码块,即:th:fragment="fragmentname"
  3. id:HTML的id选择器,使用时要在前面加上#号,不支持class选择器;
  4. 代码块表达式需要配合th属性(th:insert,th:replace,th:include)一起使用:

   th:insert:将代码块片段整个插入到使用了th:insert的HTML标签中;

   th:replace:将代码块片段整个替换使用了th:replace的HTML标签中;

   th:include:将代码块片段包含的内容插入到使用了th:include的HTML标签中。

5、*{...} 选择(星号)变量表达式,Selection Variable Expressions

  选择表达式很像变量表达式,不过它们用一个预先选择的对象来代替上下文变量容器(map)来执行。

  变量表达式使用频率最高,其功能也是非常的丰富。所以我们先从简单的代码块表达式开始,然后是消息表达式,再是链接表达式,最后是变量表达式,随带介绍选择变量表达式。


内置对象和方法

1、内置对象

2、内置方法

表达式支持的语法

字面(Literals)

文本操作(Text operations)

算术运算(Arithmetic operations)

布尔操作(Boolean operations)

比较和等价(Comparisons and equality)

条件运算符(Conditional operators)


常用 th 属性

  html有的属性,Thymeleaf基本都有,而常用的属性大概有七八个。其中th属性执行的优先级从1~8,数字越低优先级越高。


总结

  总体来说,thymelaf 的使用还是很简单的。

  这篇文章参照了 thymelaf 官方文档 ,所列举的都为常用的一些用法或者语法。当然,如果读者的英文阅读能力不错,推荐将 官方文档 通读一遍,细枝末节之处将更加清晰。另一方面,如果读者的基础比较强,作者建议去阅读 thymelaf 的源码。模板引擎,其实大体的原理都接近。此处篇幅所限,不做深入讲解。

  后续如果有时间,作者将跟大家一起学习、分享源码系列。


参考

   thymelaf 官方文档




标签:优先级,SpringBoot,第十篇,thymeleaf,th,上下文,方法,order,表达式
来源: https://www.cnblogs.com/yanfei1819/p/10931435.html