Spring 全家桶之 Spring Boot 2.6.4(五)- WebMvcAutoConfiguration(Part B)

简介: Spring 全家桶之 Spring Boot 2.6.4(五)- WebMvcAutoConfiguration(Part B)

二、 Thymeleaf模板引擎

Spring Boot由于使用了嵌入式的Tomcat,不再支持JSP,Spring Boot官方推荐使用Thymeleaf模板引擎对后端传来的数据在前端进行处理和展示。

模板引擎的思想

image.png

Thymeleaf is a modern server-side Java template engine for both web and standalone environments.

Thymeleaf's main goal is to bring elegant natural templates to your development workflow — HTML that can be correctly displayed in browsers and also work as static prototypes, allowing for stronger collaboration in development teams.

With modules for Spring Framework, a host of integrations with your favourite tools, and the ability to plug in your own functionality, Thymeleaf is ideal for modern-day HTML5 JVM web development — although there is much more it can do.

Thymeleaf是一个现代的服务器端Java模板引擎,适用于Web和非Web项目的工程中。

Thymeleaf的主要目标是为您的开发工作流程带来优雅的自然模板——HTML可以在浏览器中正确显示,也可以作为静态原型工作,允许开发团队进行更强的协作。

Thymeleaf可以和Spring集成,可以使用到Spring的特性,以及插入自己功能的能力,Thymeleaf是现代HTML5 JVM web开发的理想选择——尽管它可以做的事情更多。

Spring Boot官方提供了Thymeleaf的Starter,可以在创建工程时选择Thymeleaf,也可以在pom文件中直接添加Thymeleaf Starter

<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-thymeleaf</artifactId>
</dependency>
复制代码

Thymeleaf 自动配置

Spring Boot中Thymeleaf模板引擎的自动配置类是org.springframework.boot.autoconfigure.thymeleaf包下的ThymeleafAutoConfiguration

image.png

这个自动配置类启用了ThymeleafProperties配置类

image.png

Spring Boot自动配置好了前缀和后置以及内容类型等配置,只要把HTML页面放在classpath:/template下,thymeleaf就能自动渲染html页面。

Thymeleaf 语法

使用Thymeleaf

在classpath:/template目录下创建一个success.html页面

<!DOCTYPE html>
<html lang="en" xmlns:th="http://www.thymeleaf.org">
<head>
    <meta charset="UTF-8"/>
    <title>Success</title>
</head>
<body>
    <h1>Thymeleaf模板引擎成功渲染页面</h1>
</body>
</html>
复制代码

HelloController中增加一个方法,返回success.html页面

@RequestMapping("/success")
public String success(){
    return "success";
}
复制代码

重新启动应用,在浏览器中输入localhost:8080/success

image.png

浏览器跳转到template目录下的success.html页面。

Thymeleaf语法初体验

修改HelloController

@RequestMapping("/success")
public String success(HttpServletRequest request, Map<String, Object> map){
    map.put("name","Thymeleaf");
    return "success";
}
复制代码

修改success.html,首先导入thymeleaf名称空间,再对后端传出来的数据进行处理和展示

<!DOCTYPE html>
<html lang="en" xmlns:th="http://www.thymeleaf.org">
<head>
    <meta charset="UTF-8"/>
    <title>Success</title>
</head>
<body>
    <h1>Thymeleaf模板引擎成功渲染页面</h1>
    <h2>取出map中存的数据</h2>
    <!--将内容设置为指定值-->
    <div id="div01" class="class01" th:text="${name}"></div>
</body>
</html>
复制代码

重启应用,浏览器再次访问localhost:8080/success

image.png

html页面成功渲染了来自后端的数据

Tymeleaf th 语法规则

Thymeleaf的语法规则可以参考Thymeleaf 官网

th:text;改变当前元素里面的文本内容 th:任意html属性;可以替换原属性的值 修改success.html页面,增加属性

<div id="div01" class="class01" th:id="${name}" th:class="${name}" th:text="${name}"></div>
复制代码

重启应用,浏览器访问/success

image.png

属性值全部被取代

th:语法可以参考官方文档 Attribute Precedence

image.png

Thymeleaf 表达式语法

表达式语法可以参考官网 Standard Expression Syntax

  • Simple expressions: 简单表达式
  • Variable Expressions: ${...} 获取变量值,可以参考 官网文档 4.2 Variables
  • 获取对象属性,调用对象方法
  • 使用内置的基本对象,包括请求对象响应对象session对象区域对象以及servletContext上下文对象等
  • 可以使用内置的工具对象
  • Selection Variable Expressions: *{...} 变量选择表达式,参考官网 4.3 Expressions on selections (asterisk syntax)
  • Message Expressions: #{...} 获取国际化内容,可以参考官网 4.1 Messages
  • Link URL Expressions: @{...} URL表达式,参考官网 4.4 Link URLs
  • Fragment Expressions: ~{...}片段引用表达式,参考官网 4.5 Fragments
  • Literals:字面量
  • 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,…
  • Text operations:文本操作
  • String concatenation: +
  • Literal substitutions: |The name is ${name}|
  • Arithmetic operations: 数学运算
  • Binary operators: +, -, *, /, %
  • Minus sign (unary operator): -
  • Boolean operations: 布尔运算
  • Binary operators: and, or
  • Boolean negation (unary operator): !, not
  • Comparisons and equality: 比较运算
  • Comparators: >, <, >=, <= (gt, lt, ge, le)
  • Equality operators: ==, != (eq, ne)
  • Conditional operators: 条件运算,支持三元运算符
  • If-then: (if) ? (then)
  • If-then-else: (if) ? (then) : (else)
  • Default: (value) ?: (defaultvalue)
  • Special tokens: 特殊操作符
  • No-Operation: _

在success方法中,多放一些数据,在页面上获取并展示

map.put("users", Arrays.asList("stark","banner","stranger","peter","thor"));
复制代码

success页面使用thymeleaf获取map中的数据并展示

<h2>取出users列表中的数据</h2>
<div>第一种方式</div>
<h3 th:text="${user}" th:each="user:${users}"></h3>
<div>第二种方式,一行内</div>
<div>
    <span th:each="user:${users}">[[${user}]] </span>
</div>
复制代码

重新启动应用,浏览器输入localhost:8080/success

image.png

页面上成功展示出map中存储的数据


相关文章
|
23天前
|
监控 Java 应用服务中间件
SpringBoot是如何简化Spring开发的,以及SpringBoot的特性以及源码分析
Spring Boot 通过简化配置、自动配置和嵌入式服务器等特性,大大简化了 Spring 应用的开发过程。它通过提供一系列 `starter` 依赖和开箱即用的默认配置,使开发者能够更专注于业务逻辑而非繁琐的配置。Spring Boot 的自动配置机制和强大的 Actuator 功能进一步提升了开发效率和应用的可维护性。通过对其源码的分析,可以更深入地理解其内部工作机制,从而更好地利用其特性进行开发。
42 6
|
29天前
|
XML Java 应用服务中间件
Spring Boot 两种部署到服务器的方式
本文介绍了Spring Boot项目的两种部署方式:jar包和war包。Jar包方式使用内置Tomcat,只需配置JDK 1.8及以上环境,通过`nohup java -jar`命令后台运行,并开放服务器端口即可访问。War包则需将项目打包后放入外部Tomcat的webapps目录,修改启动类继承`SpringBootServletInitializer`并调整pom.xml中的打包类型为war,最后启动Tomcat访问应用。两者各有优劣,jar包更简单便捷,而war包适合传统部署场景。需要注意的是,war包部署时,内置Tomcat的端口配置不会生效。
231 17
Spring Boot 两种部署到服务器的方式
|
1月前
|
缓存 安全 Java
Spring Boot 3 集成 Spring Security + JWT
本文详细介绍了如何使用Spring Boot 3和Spring Security集成JWT,实现前后端分离的安全认证概述了从入门到引入数据库,再到使用JWT的完整流程。列举了项目中用到的关键依赖,如MyBatis-Plus、Hutool等。简要提及了系统配置表、部门表、字典表等表结构。使用Hutool-jwt工具类进行JWT校验。配置忽略路径、禁用CSRF、添加JWT校验过滤器等。实现登录接口,返回token等信息。
359 12
|
1月前
|
存储 安全 Java
Spring Boot 3 集成Spring AOP实现系统日志记录
本文介绍了如何在Spring Boot 3中集成Spring AOP实现系统日志记录功能。通过定义`SysLog`注解和配置相应的AOP切面,可以在方法执行前后自动记录日志信息,包括操作的开始时间、结束时间、请求参数、返回结果、异常信息等,并将这些信息保存到数据库中。此外,还使用了`ThreadLocal`变量来存储每个线程独立的日志数据,确保线程安全。文中还展示了项目实战中的部分代码片段,以及基于Spring Boot 3 + Vue 3构建的快速开发框架的简介与内置功能列表。此框架结合了当前主流技术栈,提供了用户管理、权限控制、接口文档自动生成等多项实用特性。
83 8
|
2月前
|
缓存 前端开发 Java
【Spring】——SpringBoot项目创建
SpringBoot项目创建,SpringBootApplication启动类,target文件,web服务器,tomcat,访问服务器
|
2月前
|
负载均衡 Java 开发者
深入探索Spring Cloud与Spring Boot:构建微服务架构的实践经验
深入探索Spring Cloud与Spring Boot:构建微服务架构的实践经验
209 5
|
3月前
|
监控 Java 数据库连接
详解Spring Batch:在Spring Boot中实现高效批处理
详解Spring Batch:在Spring Boot中实现高效批处理
468 12
|
3月前
|
安全 Java 测试技术
详解Spring Profiles:在Spring Boot中实现环境配置管理
详解Spring Profiles:在Spring Boot中实现环境配置管理
161 10
|
3月前
|
存储 运维 安全
Spring运维之boot项目多环境(yaml 多文件 proerties)及分组管理与开发控制
通过以上措施,可以保证Spring Boot项目的配置管理在专业水准上,并且易于维护和管理,符合搜索引擎收录标准。
79 2
|
4月前
|
Java 测试技术 开发者
springboot学习四:Spring Boot profile多环境配置、devtools热部署
这篇文章主要介绍了如何在Spring Boot中进行多环境配置以及如何整合DevTools实现热部署,以提高开发效率。
157 2