今天看到一个讨论群里说,每天套模板 改这些jstl 该标签 改起来麻烦死了,有没有不用改模板,直接套用模板 实现JSTL ognl表达式效果的技术呢? 肯定是有 那就是Thymeleaf
http://www.oschina.net/p/thymeleaf 介绍
Thymeleaf是一个XML/XHTML/HTML5模板引擎,可用于Web与非Web环境中的应用开发。它是一个开源的Java库,基于Apache License 2.0许可,由Daniel Fernández创建,该作者还是Java加密库Jasypt的作者。
Thymeleaf提供了一个用于整合Spring MVC的可选模块,在应用开发中,你可以使用Thymeleaf来完全代替JSP,或其他模板引擎,如Velocity、FreeMarker等。Thymeleaf的主要目标在于提供一种可被浏览器正确显示的、格式良好的模板创建方式,因此也可以用作静态建模。你可以使用它创建经过验证的XML与HTML模板。相对于编写逻辑或代码,开发者只需将标签属性添加到模板中即可。接下来,这些标签属性就会在DOM(文档对象模型)上执行预先制定好的逻辑。
示例模板:
<table>
<thead>
<tr>
<th th:text="#{msgs.headers.name}">Name</td>
<th th:text="#{msgs.headers.price}">Price</td>
</tr>
</thead>
<tbody>
<tr th:each="prod : ${allProducts}">
<td th:text="${prod.name}">Oranges</td>
<td th:text="${#numbers.formatDecimal(prod.price,1,2)}">0.99</td>
</tr>
</tbody>
</table>
这段介绍下面的实例模板 稍后我会逐一解释
使用步骤
第一步 往 html页面加入头文件 相应的schema 就是这个网址
1
2
3
|
<! DOCTYPE html>
< html xmlns = "http://www.w3.org/1999/xhtml"
xmlns:th = "http://www.thymeleaf.org" >
|
第二步就是你的原始模板
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
|
< table class = "box-table-a" >
< caption >thyMeleaf使用教程</ caption >
< thead >
< tr >
< th scope = "col" >ID</ th >
< th scope = "col" >这是标题1</ th >
< th scope = "col" >这是标题2</ th >
< th scope = "col" >这是标题3</ th >
</ tr >
</ thead >
< tbody >
< tr >
< td >1</ td >
< td >朱遇平</ td >
< td >java</ td >
< td >程序猿</ td >
</ tr >
< tr >
< td >2</ td >
< td >张三</ td >
< td >php</ td >
< td >程序猿</ td >
</ tr >
< tr >
< td >3</ td >
< td >李四</ td >
< td >c++</ td >
< td >程序猿</ td >
</ tr >
</ tbody >
</ table >
|
第三部就是怎么采用ThyMeleaf标签替换这些了 而不用改动模板以及样式 thyMeleaf 是一个基于标签 自定义属性实现的一个模板引擎 ,这里怎么配置Thymeleaf先不说 到后面再说,先说说他的标签用法
网上有一篇文章 总结的不错 地址 http://www.blogjava.net/bjwulin/archive/2013/02/07/395234.html
这里我想详细的讲下 讲完了 我就把上面的模型改成修改后的
# 代表 获取对象 从 messages bundle 也就是消息的资源本地化文件
$ 表示从model里面获取
# $这2个可以一起用 比如#{'system.'+${model.id}} -----这相当于 #{system.01}的资源本地化文件中的system.01内容
下面介绍常用的标签
th:fragment=“public” 相当于 include标签
th:each="user : ${users}" 相当于c:foreach 使用时候
如上面
<tr th:each="user : ${users}">
<td th:text="${user.id}">01</td>
<td th:text="${user.name}">朱遇平</td>
<td th:text="${user.xx}">java</td>
<td th:text="${user.xx}">程序员</td>
</tr>
这些静态数据不要管他 当运行时候自动替换
上面注意到th:text="${user.id}" 这是代表着运行时候动态设置标签为用户的id属性的值
th:href="@{/users/delete(id=${u.id})}">
这是动态设置url属性参考上面的文章总结
在表单的环境下 有时候我们可能需要动态数据绑定
OK thymeleaf 也有相关标签
首先了解的是
<form action="#" th:action="@{/users/add}" th:object="${myuser}" method="post">
这里th:Object表示表单与 改myuser注入的实体映射,
在表单 th:field="*{id} 则表示 该表单的值 与 myuser的id绑定
这里注意到 我上面的遍历表格只改了一个 其他的三个 你不是说可以不用改模板的 的 那该怎么办啊
th:remove="all" 使用了该标签 将在运行时候移除所有的元素
<tr th:remove="all">
</tr>
上面的其他几行 就直接相当于忽略他了
趁着中午的时间 更新下。这里先讲到这里了 有时间补充更新 它的配置 以及 spring整合
有人问我该怎么呢使用if 突然想到 我上面好像忘了讲这个
经常有由td 表格展示某一行要判断的情况
1
|
< td class = "status" th:if = "${#strings.isEmpty(status)}" th:text = "这状态为空" >这里显示状态不为空</ td >
|
同理
1
|
${not #strings.isEmpty(status)} |
换p标签 只要把td改成p标签即可
这里要提一下strings哪里来的 上面我们引用的那篇博文上的一段话
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
|
表达式基本对象: #ctx:context object #root或者#vars #locale #httpServletRequest #httpSession 表达式功能对象: #dates:java.util.Date的功能方法类。 #calendars:类似#dates,面向java.util.Calendar #numbers:格式化数字的功能方法类。 #strings:字符串对象的功能类,contains,startWiths,prepending/appending等等。 #objects:对objects的功能类操作。 #bools:对布尔值求值的功能方法。 #arrays:对数组的功能类方法。 #lists:对lists功能类方法 #sets #maps #aggregates:对数组或者集合创建聚合的功能方法, th:text="${#aggregates.sum(o.orderLines.{purchasePrice * amount})}" #messages:在变量表达式中获取外部信息的功能类方法。 #ids:处理可能重复的id属性的功能类方法。 |
看到strings了没
感谢大家的支持
附加 有同学疑问 怎么映入js css
我一般 都是 <head th:fragment="header">
<meta charset="UTF-8" />
<title th:text="#{head.title}"></title>
<meta name="viewport" content="width=device-width, initial-scale=1" />
<link rel="shortcut icon" th:href="@{/static/img/favicon.gif}" type="image/gif" />
<link rel="stylesheet" th:href="@{/resources/css/bootstrap.min.css}" />
<link rel="stylesheet" th:href="@{/resources/css/jquery.ui.all.css}" />
<link rel="stylesheet" th:href="@{/resources/css/jquery.ui.customer.css}" />
<script th:src="@{/resources/js/jquery-1.9.1.min.js}"></script>
<script th:src="@{/resource/js/bootstrap.min.js}"></script>
</head>
下面在你要的页面 引入这个片段就行<head th:include="theme/fragments::header" /> 他就相当于jsp 中我们常用的
<%@ include file="/WEB-INF/jsp/public/header.jspf"%>
那是应为注解了 <!-- <!--[if IE 7]>
<link rel="stylesheet" href="bootstrap/css/ie.css" th:href="@{/bootstrap/css/ie.css}" />
<![endif]-->
转自:http://my.oschina.net/yilian/blog/172407?p=2#comments
相关推荐
通过官方文档全译中文版,本教程提供了关于Thymeleaf的基础知识,包括其目的、可用模板类型、方言的概念以及如何使用Thymeleaf进行Web开发。对于希望提升开发效率和模板维护能力的Java开发者而言,Thymeleaf提供了一...
基于java的支持xml/xhtml/html5的模板引擎技术
`usingthymeleaf.pdf`和`thymeleaf 2.x.pdf`等文档可能包含了逐步的使用教程,从基础到进阶,帮助开发者快速上手Thymeleaf。 总的来说,这个文档合集是学习和精通Thymeleaf的宝贵资源,涵盖了从基础概念到高级特性...
html xmlns:th="http://www.thymeleaf.org"> 在html中引入此命名空间,可避免编辑器出现html验证错误,虽然加不加命名空间对Thymeleaf的功能没有任何影响。 二、输出内容 2.1 ...
在本教程中,首先会对Thymeleaf进行介绍,解释它是什么,能处理哪些类型的模板,以及Thymeleaf的标准方言。 接下来,教程会通过一个示例项目“Good Thymes Virtual Grocery”,这是一个虚拟的杂货店网站,来讲解...
Thymeleaf是一款由Pivotal公司开发的现代服务器端Java模板引擎,用于Web和独立环境。它的主要目的是在开发中提供自然的模板设计,以便开发者可以使用它进行清晰的逻辑设计,同时也可以作为Web页面渲染引擎。...
Thymeleaf的设计理念是使得静态模板在脱离服务器环境时也能正常工作,提供了一种易于阅读和维护的静态代码形式。其3.0.5版是该技术的一个稳定版本,具有诸多增强和改进。 Thymeleaf的主要特性包括: 1. **模板语言...
Tutorialspoint Thymeleaf 教程.epub
在开始本教程之前,建议先阅读“使用Thymeleaf”教程,该教程详细解释了标准方言。Thymeleaf为与Spring更好地集成提供了一种方言。这种方言基于Thymeleaf标准方言,并实现所有需要的功能,使其能够在Spring中正确...
### Thymeleaf与Spring框架整合教程 #### 概述 本教程主要介绍如何将Thymeleaf模板引擎与Spring框架进行整合,并特别关注于Spring MVC应用中的集成方式。Thymeleaf是一种现代服务器端的Java模板引擎,它可以提供...
Thymeleaf是一个流行的Java模板引擎,用于在服务器端生成HTML、XML和其他文本...为了更好地学习Thymeleaf,建议参考官方文档、在线教程以及相关的Stack Overflow问答,这样可以帮助你快速掌握其核心概念和最佳实践。
Eclipse 模板插件 Thymeleaf 是一个强大的开发工具,专为使用 Thymeleaf 模板引擎的 Java 开发者设计。Thymeleaf 是一个广泛应用于 Web 应用开发中的服务器端模板引擎,它允许开发者使用 HTML 作为模板语言,同时在...
在本教程中,我们将深入探讨一系列关键的编程和数据分析技术,包括Gson、HttpClient、Java 9、Python数据结构、SciPy以及Thymeleaf。这些技术在现代软件开发和数据分析领域都扮演着重要的角色。 首先,让我们从Gson...
- `thymeleaf-spring5.jar`(或`thymeleaf-servlet.jar`,取决于Spring版本):这个库是Thymeleaf与Spring框架集成的关键。它允许Thymeleaf与Spring MVC无缝协作,提供模型数据注入、视图解析等功能。 4. **...
在Spring框架中,Thymeleaf通常作为视图解析器使用,为开发人员提供了便捷的方式来构建动态Web页面。Thymeleaf-3.0.11.RELEASE是该引擎的一个特定版本,它包含了优化和修复的特性,以提高性能和稳定性。 1. **...
thymeleaf,我个人认为是个比较好的模板,性能也比一般的,比如freemaker的要高,而且把将美工和程序员能够结合起来,美工能够在浏览器中查看静态效果,程序员可以在应用服务器查看带数据的效果。 thymeleaf是一个...
Thymeleaf是一个面向web和独立环境的现代服务器端Java模板引擎。 Thymeleaf的主要目标是将优雅的自然模板引入到您的开发工作流程中——可以在浏览器中正确显示的HTML,也可以作为静态原型工作,从而在开发团队中实现...
本案例将详细讲解如何将SpringBoot与Thymeleaf进行整合,构建一个完整的Web应用。 首先,我们需要在SpringBoot项目中引入Thymeleaf的依赖。在`pom.xml`文件中,添加如下Maven依赖: ```xml <groupId>org.spring...
SpringBoot整合Thymeleaf模板是一项常见的Web开发任务,它结合了SpringBoot的便捷性和Thymeleaf的动态模板引擎,使得开发人员可以快速构建功能丰富的Web应用。下面将详细介绍这个过程及其涉及的关键知识点。 首先,...