Thymeleaf内置对象、定义变量、URL参数及标签自定义属性

简介: Thymeleaf内置对象、定义变量、URL参数及标签自定义属性


本文主要讲述Thymeleaf中的内置对象(list解析、日期格式化、数字格式化等)、定义变量、获取URL的参数和在页面标签中自定义属性的应用。

  • Controller部份
@Controller
public class IndexController {
    @GetMapping(value = "index")
    public String index(Model model, HttpServletRequest request) {
        List<String> datas = new ArrayList<String>();
        datas.add("知识林");
        datas.add("http://www.zslin.com");
        datas.add("393156105");
        model.addAttribute("datas", datas);
        model.addAttribute("curDate", new Date());
        model.addAttribute("money", Math.random()*100);
        return "index";
    }
}
  • 在这个控制器的Model中存放了这样几个数据:一个String类型的列表、一个日期对象和一个数值,这些东西在实际应用开发过程中应用非常广泛,下面具体看一下在Thymeleaf中是如何解析这些数据的。
  • 日期格式化
<span th:text="${#dates.format(curDate, 'yyyy-MM-dd HH:mm:ss')}"></span>
  • 说明: 使用内置对象dates的format函数即可对日期进行格式化,在format函数中,第一个参数是日期对象,对二两个参数为日期格式(规则跟SimpleDateFormat一样)需要注意的是:
  • 内置对象一般都以s结尾,如dates、lists、numbers等
  • 在使用内置对象是在对象名前都需要加#号。
  • 数字格式化
<span th:text="${#numbers.formatDecimal(money, 0, 2)}"></span>
  • 说明: 此示例表示保留两位小数位,整数位自动;
<span th:text="${#numbers.formatDecimal(money, 3, 2)}"></span>
• 1
  • 说明: 此示例表示保留两位小数位,3位整数位(不够的前加0)
  • 获取列表长度
<span th:text="${#lists.size(datas)}"></span>
  • 说明: 使用#lists.size来获取List的长度。
  • 获取URL参数值
<span th:text="${#httpServletRequest.getParameter('page')}"></span>
  • 说明: 当访问http://localhost:1105/index?page=5时页面将会得到page对应的值:5
  • 定义变量
<div th:with="curPage=${#httpServletRequest.getParameter('page')}">
    <h3>当前页码:<span th:text="${curPage}"></span></h3>
</div>
  • 说明: 同样,当访问http://localhost:1105/index?page=5时,页面将显示:当前页码:5,说明用th:with来定义变量,多个用,号隔开,使用范围在当前标签内。
  • 自定义标签属性
    在Thymeleaf中可以使用th:加上标签的任何属性进行赋值,但有些时候会遇到自定义的属性,再用th:加自定义的属性则会无效。比如:需要对标签增加objName和objId这样的属性,在非Thymeleaf情况下是这样:
<span objId="1" objName="知识林"></span>
  • 变量情况是:
<span objId="${obj.id}" objName="${obj.name}"></span>
  • 在Thymeleaf下则是:
<span th:attr="myDate=${#dates.format(curDate, 'yyyy-mm-dd')}, myMoney=${money}"></span>
  • 说明: 在页面上查看源代码可以看到:,说明自定义属性用:th:attr,多个属性用,隔开。
  • 内置对象上面简单描述了比较常用的dates、lists、numbers这几个内置对象,在Thymeleaf还有很多的内置对象,像strings也非常常用,用法跟java.lang.String类的用法一样。在Thymeleaf中的内置对象有:
  • #dates:日期格式化内置对象,具体方法可以参照java.util.Date;
  • #calendars:类似于#dates,但是是java.util.Calendar类的方法;
  • #numbers: 数字格式化;
  • #strings:字符串格式化,具体方法可以参照java.lang.String,如startsWith、contains等;
  • #objects:参照java.lang.Object;
  • #bools:判断boolean类型的工具;
  • #arrays:数组操作的工具;
  • #lists:列表操作的工具,参照java.util.List;
  • #sets:Set操作工具,参照java.util.Set;
  • #maps:Map操作工具,参照java.util.Map;
  • #aggregates:操作数组或集合的工具;
  • #messages:操作消息的工具。


相关文章
|
安全 Java 网络安全
【认知革命】JAVA网络编程新视角:重新定义URL与URLConnection,让网络资源触手可及!
【认知革命】JAVA网络编程新视角:重新定义URL与URLConnection,让网络资源触手可及!
100 2
|
12月前
|
前端开发 JavaScript
前端JS截取url上的参数
文章介绍了两种前端JS获取URL参数的方法:手动截取封装和使用URLSearchParams。
249 0
|
Python
url标签
【6月更文挑战第29天】url标签。
120 5
|
开发框架 前端开发 .NET
Asp.net Webapi 的 Post 方法不能把参数加到 URL 中?试试这样写
Asp.net Webapi 的 Post 方法不能把参数加到 URL 中?试试这样写
160 0
|
Java
JAVA 获取 URL 指定参数的值
JAVA 获取 URL 指定参数的值
139 0
|
安全 Java 网络安全
【认知革命】JAVA网络编程新视角:重新定义URL与URLConnection,让网络资源触手可及!
【6月更文挑战第22天】JAVA网络编程中,URL代表统一资源定位符,用于表示网络资源地址。通过`new URL(&quot;address&quot;)`创建URL对象,可解析和访问其组件。URLConnection是与URL建立连接的接口,用于定制HTTP请求,如设置GET/POST、超时及交换数据。
95 1
|
JavaScript 前端开发 数据格式
URL编码【详解】——Javascript对URL进行编码解码的三种方式的区别和使用场景,axios请求拦截器中对get请求的参数全部进行URL编码
URL编码【详解】——Javascript对URL进行编码解码的三种方式的区别和使用场景,axios请求拦截器中对get请求的参数全部进行URL编码
713 0
|
JavaScript
js 获取并解析 url 中参数的三种方法
js 获取并解析 url 中参数的三种方法
1712 0
|
文字识别 算法 API
视觉智能开放平台产品使用合集之在调用接口传入的图片URL参数,文件在本地或者非上海地域OSS链接,该怎么办
视觉智能开放平台是指提供一系列基于视觉识别技术的API和服务的平台,这些服务通常包括图像识别、人脸识别、物体检测、文字识别、场景理解等。企业或开发者可以通过调用这些API,快速将视觉智能功能集成到自己的应用或服务中,而无需从零开始研发相关算法和技术。以下是一些常见的视觉智能开放平台产品及其应用场景的概览。
124 0
|
存储 JavaScript 前端开发
js原生方法,获取url上面所有参数,并返回一个对象
JavaScript函数`getUrlParameters`用于从URL中提取所有参数并返回一个键值对对象。它接收URL,分割查询字符串,解码参数对,并存储在对象中。重复参数键会被存储为数组。