一.简介
  1.thymeleaf优点
    ①是一个支持html原型的自然引擎,它在html标签增加额外的属性来达到模板+数据的展示方式,由于浏览器解释html时,忽略未定义的标签属性,因此thymeleaf的模板可以静态运行。;当有数据返回到页面时,Thymeleaf 标签会动态地替换掉静态内容,使页面动态显示。
    ②提供标准和spring标准两种方言,可以直接套用模板实现JSTL、OGNL表达式效果,同时开发人员也可以扩展和创建自定义的方言。
    ③提供spring标准方言和一个与SpringMVC 完美集成的可选模块,可以快速的实现表单绑定、属性编辑器等功能
  2.模板样式
    允许使用六种模板,每个被称为一种模板模式:HTML、XML、TEXT、JAVASCRIPT、CSS、RAW。这其中有两种标记语言模板模式(HTML,XML),三种文本语言模板模式(TEXT,JAVASCRIPT,CSS),和一种无操作模板模式(RAW)
  3.官网地址:http://www.thymeleaf.org
二.集成方式
  1.thymeleaf + SpringMVC
    ❶引入相应jar包


    ❷在xml中配置thymeleaf视图解析器


    ❸传统jsp开发采用SpringMVC的视图解析器


    ❹集成了Spring 3.x 和Spring 4.x 根据需要选择不同的jar包
  官网地址:http://www.thymeleaf.org/doc/tutorials/3.0/thymeleafspring.html
  2.thymeleaf + SpringBoot
    ❶引入相应jar包


    ❷在yml中配置thymeleaf视图解析器


  3.HTML头文件格式

三.标准表达式语法
1.支持语法

  • 简单表达式:
  1. 变量表达式: ${...}
  2. 选择变量表达式: *{...}
  3. 消息表达式: #{...}
  4. 链接URL表达式: @{...}
  5. 片段表达式: ~{...}
  • 字面
  1. 文本文字:'one text','Another one!',...
  2. 号码文字:0,34,3.0,12.3,...
  3. 布尔文字:true,false
  4. 空文字: null
  5. 文字标记:one,sometext,main,...
  6. 文字操作:
  7. 字符串连接: +
  8. 文字替换: |The name is ${name}|
  • 算术运算:
  1. 二元运算符:+,-,*,/,%
  2. 减号(一元运算符): -
  • 布尔运算:
  1. 二元运算符:and,or
  2. 布尔否定(一元运算符): !,not
  • 比较和平等:
  1. 比较:>,<,>=,<=(gt,lt,ge,le)
  2. 平等运营商:==,!=(eq,ne)
  • 有条件的操作符:
  1. IF-THEN: (if) ? (then)
  2. IF-THEN-ELSE: (if) ? (then) : (else)
  3. 默认: (value) ?: (defaultvalue)
  • 特殊令牌:
  1. 无操作: _

2.变量表达式


3.选择表达式(也叫星号表达式)


4.文字国际化表达式
  从一个外部文件获取区域文字信息(.properties)。
  th:text:转义HTML代码
  th:utext:不会转义HTML代码


5.URL表达式
  绝对路径:@{ http://www.thymeleaf.org}
  相对路径:@{/order/{id}/details(id=${orderId})}
6.内联js
  引入 th:inline="javascript"
  [[***]]:转义HTML代码
  [(***)]:不会转义HTML代码


7.模板布局(片段引用)
  引入 th:fragment 或者直接使用选择器
  th:insert:插入指定的片段作为其主机标签的主体
  th:replace:用指定的片段来替换它的主机标签
  th:include:只是插入这个片段的内容


8.常用th标签


9.表达式工具对象
  #execInfo:关于正在处理的模板的信息。
  #messages:在变量表达式中获得外部化消息的方法,与使用#{...}语法获得的方式相同。
  #uris:用于转义URL / URI部分的方法
  #conversions:执行配置的转换服务的方法(如果有的话)。
  #dates:针对java.util.Date对象的方法,包括日期格式化等
  #calendars:类似于#dates,但是对于java.util.Calendar对象。
  #numbers:针对numeric对象格式化的方法。
  #strings:针对String对象的方法:contains,startsWith,prepending / appending等
  #objects:针对object的方法。
  #bools:针对boolean运算的方法。
  #arrays:针对数组的方法。
  #lists:针对List的方法。
  #sets:针对Set的方法。
  #maps:针对Map的方法。
  #aggregates:在数组或集合上创建聚合的方法。
  #ids:处理可能重复的id属性的方法(例如,作为迭代的结果)。
    例如:
      dates
        ${#dates.format(date, 'dd/MMM/yyyy HH:mm')}
        ${#dates.arrayFormat(datesArray, 'dd/MMM/yyyy HH:mm')}
        ${#dates.listFormat(datesList, 'dd/MMM/yyyy HH:mm')}
        ${#dates.setFormat(datesSet, 'dd/MMM/yyyy HH:mm')}
        ${#dates.createNow()}
        ${#dates.createToday()}
      strings
        ${#strings.isEmpty(name)}
        ${#strings.arrayIsEmpty(nameArr)}
        ${#strings.listIsEmpty(nameList)}
        ${#strings.setIsEmpty(nameSet)}
        ${#strings.length(str)}
        ${#strings.equals(str)}
        ${#strings.equalsIgnoreCase(str)}

Thymeleaf入门基础的更多相关文章

  1. mybatis入门基础(二)----原始dao的开发和mapper代理开发

    承接上一篇 mybatis入门基础(一) 看过上一篇的朋友,肯定可以看出,里面的MybatisService中存在大量的重复代码,看起来不是很清楚,但第一次那样写,是为了解mybatis的执行步骤,先 ...

  2. 01shell入门基础

    01shell入门基础 为什么学习和使用shell编程 shell是一种脚本语言,脚本语言是相对于编译语言而言的.脚本语言不需要编译,由解释器读取程序并且执行其中的语句,而编译语言需要编译成可执行代码 ...

  3. Markdown入门基础

    // Markdown入门基础 最近准备开始强迫自己写博文,以治疗严重的拖延症,再不治疗就“病入骨髓,司命之所属,无奈何”了啊.正所谓“工欲善其事,必先利其器”,于是乎在写博文前,博主特地研究了下博文 ...

  4. JavaScript入门基础

    JavaScript基本语法 1.运算符 运算符就是完成操作的一系列符号,它有七类: 赋值运算符(=,+=,-=,*=,/=,%=,<<=,>>=,|=,&=).算术运 ...

  5. C++ STL编程轻松入门基础

    C++ STL编程轻松入门基础 1 初识STL:解答一些疑问 1.1 一个最关心的问题:什么是STL 1.2 追根溯源:STL的历史 1.3 千丝万缕的联系 1.4 STL的不同实现版本 2 牛刀小试 ...

  6. HTML入门基础教程相关知识

    HTML入门基础教程 html是什么,什么是html通俗解答: html是hypertext markup language的缩写,即超文本标记语言.html是用于创建可从一个平台移植到另一平台的超文 ...

  7. Linux shell入门基础(六)

    六.Shell脚本编程详解 将上述五部分的内容,串联起来,增加对Shell的了解 01.shell脚本 shell: # #perl #python #php #jsp 不同的脚本执行不同的文本,执行 ...

  8. Linux shell入门基础(一)

    Linux shell入门基础(一): 01.增加删除用户: #useradd byf   userdel byf(主目录未删除)  userdel -r byf   该用户的属性:usermod 用 ...

  9. AngularJS入门基础PPT(附下载链接)

    学习了Angularjs有段时间,自己写了一个PPT,个人认为总结的非常全面,对于入门基础够了. 大致模块有:Angularjs简单介绍,Angularjs特性,hello world,Control ...

随机推荐

  1. Python实现简易Web服务器

     1.请自行了解HTTP协议 http://www.cnblogs.com/reboot51/p/8358129.html(点击跳转) 2.创建Socket服务,监听指定IP和端口 3.以阻塞方式等待 ...

  2. 注释中不允许出现字符串 "--"。

    问题: 在启动tomcat时会出现如上错误,同时有可能会出现xml无法解析等错误 解决办法: 注释中不能出现字符串 "--",即需要把xml文件中多余的“--”去掉,例如: < ...

  3. java8-新特性--(接口的默认方法与静态方法)

    Java 8用默认方法与静态方法这两个新概念来扩展接口的声明. public interface Inte{ void method(); default void defaultMethod(){ ...

  4. 【fail2ban】使用fail2ban进行攻击防范

    使用fail2ban进行攻击防范 转自:https://kyle.ai/blog/6215.html 最近总有一些无聊的人,会来扫描一下我的服务器,看有没有啥漏洞可以利用的... 可以看到类似这样的4 ...

  5. JAR包数字签名与验证

    经签名的Jar包内包含了以下内容: 原Jar包内的class文件和资源文件 签名文件 META-INF/*.SF:这是一个文本文件,包含原Jar包内的class文件和资源文件的Hash 签名block ...

  6. 在Tomcat中配置单点登录

    单点登录:Single Sign-On .概述 一旦你设置了realm和验证的方法,你就需要进行实际的用户登录处理.一般说来,对用户而言登录系统是一件很麻烦的事情,你必须尽量减少用户登录验证的次数.作 ...

  7. fullpage.js的easing参数怎样配置自定义动画

    首先看非官方文档 并没有详细的说明怎样去使用easing.js,所以我加的运动属性根本就不起作用, 再看,官方文档 Optionally, when using css3:false, you can ...

  8. z-index在IE中的坑

    在CSS2.1规范中,每个盒模型的位置是三维的,分别是平面画布上的x轴,y轴以及表示层叠的z轴.对于每个html元素,都可以通过设置z-index属性来设置该元素在视觉渲染模型中的层叠顺序. z-in ...

  9. Git Batch命令(转)

    echo 和 @ 回显命令 @ #关闭单行回显 echo off #从下一行开始关闭回显 @echo off #从本行开始关闭回显.一般批处理第一行都是这个 echo on #从下一行开始打开回显 e ...

  10. How to create and start VirtualBox VM without GUI

    Suppose you want to create and run virtual machines (VMs) on VirtualBox. However, a host machine doe ...