RELATEED CONSULTING
相关咨询
选择下列产品马上在线沟通
服务时间:8:30-17:00
你可能遇到了下面的问题
关闭右侧工具栏

新闻中心

这里有您想知道的互联网营销解决方案
SpringBoot中Thymeleaf如何使用

本篇文章给大家分享的是有关SpringBoot 中Thymeleaf如何使用,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。

成都创新互联公司专注于大理州网站建设服务及定制,我们拥有丰富的企业做网站经验。 热诚为您提供大理州营销型网站建设,大理州网站制作、大理州网页设计、大理州网站官网定制、微信小程序开发服务,打造大理州网络公司原创品牌,更为您提供大理州网站排名全网营销落地服务。

  1. 标准表达式语法

  • 变量表达式

变量表达式即 OGNL 表达式或 Spring EL 表达式(在 Spring 术语中也叫 model attributes)。如下所示:

${session.user.name}

它们将以HTML标签的一个属性来表示:


  • 选择(星号)表达式

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

*{customer.name}

被指定的 object 由 th:object 属性定义:


  ...
  ...
  ...
  • 文字国际化表达式

文字国际化表达式允许我们从一个外部文件获取区域文字信息(.properties),用 Key 索引 Value,还可以提供一组参数(可选).

#{main.title}  
#{message.entrycreated(${entryId})}

可以在模板文件中找到这样的表达式代码:


  ...
  ...
  ...
  ...
  • URL表达式

URL 表达式指的是把一个有用的上下文或回话信息添加到 URL,这个过程经常被叫做 URL 重写。

@{/order/list}

URL还可以设置参数:

@{/order/details(id=${orderId})}

相对路径:

@{../documents/report}

让我们看这些表达式:


  • 变量表达式和星号表达式有什么区别?

如果不考虑上下文的情况下,两者没有区别;星号语法评估在选定对象上表达,而不是整个上下文 什么是选定对象?就是父标签的值,如下:


  

Name: Sebastian.

  

Surname: Pepper.

  

Nationality: Saturn.

这是完全等价于:


  

Name: Sebastian.

  

Surname: Pepper.

  

Nationality: Saturn.

当然,美元符号和星号语法可以混合使用:


	  

Name: Sebastian.

     

Surname: Pepper.

      

Nationality: Saturn.

  
  • 表达式支持的语法

    • If-then:(if) ? (then)

    • If-then-else:(if) ? (then) : (else)

    • Default: (value) ?:(defaultvalue)

    • 所有这些特征可以被组合并嵌套:

    • 比较(Comparators):>, <, >=, <= (gt, lt, ge, le)

    • 等值运算符(Equality operators):==, != (eq, ne)

    • 二元运算符(Binary operators):and, or

    • 布尔否定(一元运算符)Boolean negation (unary operator):!, not

    • 二元运算符(Binary operators):+, -, *, /, %

    • 减号(单目运算符)Minus sign (unary operator):-

    • 字符串连接(String concatenation):+

    • 文本替换(Literal substitutions):|The name is ${name}|

    • 文本文字(Text literals): 'one text', 'Another one!',…

    • 数字文本(Number literals): 0, 34, 3.0, 12.3,…

    • 布尔文本(Boolean literals): true, false

    • 空(Null literal):null

    • 文字标记(Literal tokens): one, sometext, main,…

    • 字面(Literals)

    • 文本操作(Text operations)

    • 算术运算(Arithmetic operations)

    • 布尔操作(Boolean operations)

    • 比较和等价(Comparisons and equality)

    • 条件运算符Conditional operators)

      	'User is of type ' + (${user.isAdmin()} ? 'Administrator' : (${user.type} ?: 'Unknown'))

  1. 常用th标签有哪些?

关键字功能介绍案例
th:id替换id
th:text文本替换

description

th:utext支持html的文本替换

conten

th:object替换对象
th:value属性赋值
th:with变量赋值运算
th:style设置样式th:
th:onclick点击事件th:onclick="'getCollect()'"
th:each属性赋值tr th:each="user,userStat:${users}">
th:if判断条件
th:unless和th:if判断相反Login
th:href链接地址Login />
th:switch多路选择 配合th:case 使用
th:caseth:switch的一个分支

User is an administrator

th:fragment布局标签,定义一个代码片段,方便其它地方引用
th:include布局标签,替换内容到引入的文件 />
th:replace布局标签,替换整个标签到引入的文件
th:selectedselected选择框 选中th:selected="(${xxx.id} == ${configObj.dd})"
th:src图片类地址引入App Logo
th:inline定义js脚本可以使用变量

js 附加代码:

/*[+
var msg = 'This is a working application';
+]*/

js 移除代码:

/*[- */
var msg = 'This is a non-working template';
/* -]*/
  • 内嵌变量

为了模板更加易用,Thymeleaf 还提供了一系列 Utility 对象(内置于 Context 中),可以通过 # 直接访问:

dates : java.util.Date的功能方法类。
calendars : 类似#dates,面向java.util.Calendar
numbers : 格式化数字的功能方法类
strings : 字符串对象的功能类,contains,startWiths,prepending/appending等等。
objects: 对objects的功能类操作。
bools: 对布尔值求值的功能方法。
arrays:对数组的功能类方法。
lists: 对lists功能类方法
sets
maps

下面用一段代码来举例一些常用的方法:

dates

/*
 * Format date with the specified pattern
 * Also works with arrays, lists or sets
 */
${#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')}

/*
 * Create a date (java.util.Date) object for the current date and time
 */
${#dates.createNow()}

/*
 * Create a date (java.util.Date) object for the current date (time set to 00:00)
 */
${#dates.createToday()}

strings

/*
 * Check whether a String is empty (or null). Performs a trim() operation before check
 * Also works with arrays, lists or sets
 */
${#strings.isEmpty(name)}
${#strings.arrayIsEmpty(nameArr)}
${#strings.listIsEmpty(nameList)}
${#strings.setIsEmpty(nameSet)}

/*
 * Check whether a String starts or ends with a fragment
 * Also works with arrays, lists or sets
 */
${#strings.startsWith(name,'Don')}                  // also array*, list* and set*
${#strings.endsWith(name,endingFragment)}           // also array*, list* and set*

/*
 * Compute length
 * Also works with arrays, lists or sets
 */
${#strings.length(str)}

/*
 * Null-safe comparison and concatenation
 */
${#strings.equals(str)}
${#strings.equalsIgnoreCase(str)}
${#strings.concat(str)}
${#strings.concatReplaceNulls(str)}

/*
 * Random
 */
${#strings.randomAlphanumeric(count)}

三、使用Thymeleaf布局

Spring Boot 2.0 将布局单独提取了出来,需要单独引入依赖:thymeleaf-layout-dialect。


    org.springframework.boot
    spring-boot-starter-thymeleaf


    nz.net.ultraq.thymeleaf
    thymeleaf-layout-dialect

定义代码片段

 
© 2019

在页面任何地方引入:


    
    

th:insert 和 th:replace 区别,insert 只是加载,replace 是替换。Thymeleaf 3.0 推荐使用 th:insert 替换 2.0 的 th:replace。

返回的 HTML 如下:

 
   
 © 2019 
    
© 2019 
 

下面是一个常用的后台页面布局,将整个页面分为头部,尾部、菜单栏、隐藏栏,点击菜单只改变 content 区域的页面


  
	Header
	left
	sidebar
	
	footer
  

任何页面想使用这样的布局值只需要替换中见的 content 模块即可


 
    
  ...

也可以在引用模版的时候传参

layout 是文件地址,如果有文件夹可以这样写fileName/layout:htmlhead,htmlhead 是指定义的代码片段 如th:fragment="copy"

以上就是SpringBoot 中Thymeleaf如何使用,小编相信有部分知识点可能是我们日常工作会见到或用到的。希望你能通过这篇文章学到更多知识。更多详情敬请关注创新互联行业资讯频道。


当前标题:SpringBoot中Thymeleaf如何使用
本文网址:http://scpingwu.com/article/ggpeco.html