Springboot整合Thymeleaf

简介: Springboot整合Thymeleaf

接:[以《Springboot搭建简单demo》为基础,整合的Thymeleaf](https://blog.csdn.net/qq_44969643/article/details/106408784)



Spring Boot HTML

Spring Boot 可以结合Thymeleaf模板来整合HTML,使得原生

的HTML作为视图

Thymeleaf模板是面向web和独立环境的java模板引擎,能够处理HTML、

XML、javascript、css等。



pom.xml添加相关依赖


```java

<!--    web启动jar-->

   <dependency>

       <groupId>org.springframework.boot</groupId>

       <artifactId>spring-boot-starter-web</artifactId>

   </dependency>


   <dependency>

       <groupId>org.projectlombok</groupId>

       <artifactId>lombok</artifactId>

       <version>1.18.12</version>

       <scope>provided</scope>

   </dependency>


   <dependency>

       <groupId>org.springframework.boot</groupId>

       <artifactId>spring-boot-starter-thymeleaf</artifactId>

   </dependency>

```


application.yml


```java

server:

 port: 9090

spring:

 thymeleaf:

   prefix: classpath:/templates/

   suffix: .html

   mode: HTML5

   encoding: UTF-8

 

```


Handler


```java

package com.shuang.controller;


import org.springframework.stereotype.Controller;

import org.springframework.web.bind.annotation.GetMapping;

import org.springframework.web.bind.annotation.RequestMapping;


@Controller

@RequestMapping("/index")

public class IndexHandler {

   @GetMapping("/index")

   public String index(){

       System.out.println("index...");

       return "index";

   }

}

```


HTML


```java

<!DOCTYPE html>

<html lang="en">

<head>

   <meta charset="UTF-8">

   <title>Title</title>

</head>

<body>

   <h1>hello index</h1>

</body>

</html>

```


如果希望客户端可以直接访问HTML资源,将这些资源放置在static路径下即可,否则必须

通过Handler的后台映射才可以访问静态资源。



**Thymeleaf 常用语法**


赋值和拼接


```java

@GetMapping("/index2")

public String index2(Map<String,String> map){

   map.put("name","张三");

   return "index";

}

```


```java

<p th:text="${name}"></p>

<p th:text="'学生姓名是'+${name}+2"></p>

<p th:text="|学生姓名是,${name}|"></p>

```


条件判断:if/unless

th:if表示条件成立时显示内容,th:unless表示条件不成立时显示的内容


```java

@GetMapping("/if")

public String index3(Map<String,Boolean> map){

   map.put("flag",true);

   return "index";

}

```


```java

<p th:if="${flag==true}" th:text="if判断成立"></p>

<p th:unless="${flag!=true}" th:text="unless判断成立"></p>

```




循环


```java

@GetMapping("/index")

public String index(Model model){

   System.out.println("index...");

   List<Student> list=new ArrayList<>();

   list.add(new Student(1L,"11",11));

   list.add(new Student(2L,"22",22));

   list.add(new Student(3L,"33",33));

   list.add(new Student(4L,"44",44));

   list.add(new Student(5L,"55",55));


   model.addAttribute("list",list);

   return "index";

}

```



```java

<table>

       <tr>

           <th>index</th>

           <th>count</th>

           <th>学生ID</th>

           <th>学生姓名</th>

           <th>学生年龄</th>

       </tr>

       <tr th:each="student,stat:${list}" th:style="'background-color:

'+@{${stat.odd}?'#F2F2F2'}">

           <td th:text="${stat.index}"></td>

           <td th:text="${stat.count}"></td>

           <td th:text="${student.id}"></td>

           <td th:text="${student.name}"></td>

           <td th:text="${student.age}"></td>

       </tr>

   </table>

```


stat是状态变量,属性:

index:集合中元素的index(从0开始)

count集合中元素的count(从1开始)

size集合的大小

current当前迭代变量

even/odd当前迭代是否为偶数/奇数(从0开始)

first当前迭代的元素是否是第一个

last当前迭代的元素是否是最后一个


URL

Theymeleaf对于URL的处理是通过@(...)进行处理,结合th:href、th:src


```java

<a th:href="@{http://www.baidu.com}">跳转</a>

<a th:href="@{http://localhost:9090/index/url/{na}(na=${name})}">跳转2</a>

<img th:src="${src}">

<div th:style="'background:url('+@{${src}}+');'">

   <br>

   <br>

   <br>

</div>

```


三元运算


```java

@GetMapping("/eq")

public String eq(Model model){

   model.addAttribute("age",30);

   return "test";

}

```



```java

<input th:value="${age gt 30?'中年':'青年'}">

```


gt:great  than 大于

ge:great equal 大于等于

eq:equal等于

lt:less than 小于

le:less equal 小于等于

ne:not equal 不等于


switch


```java

@GetMapping("/switch")

public String switchTest(Model model){

   model.addAttribute("gender","女");

   return "test";

}

```



```java

<div th:switch="${gender}">

   <p th:case="女">女</p>

   <p th:case="男">男</p>

   <p th:case="*">未知</p>

</div>

```


基本对象

#cpx:上下文对象

#vars:上下文变量

#locale:区域对象

#request:HttpServletRequest对象

#response:HttpServletResponse对象

#session:HttpSession对象

#servletContext:ServletContext对象


```java

@GetMapping("/object")

public String object(HttpServletRequest request){

   request.setAttribute("request","request对象");

   request.getSession().setAttribute("session","session对象");

   return "test";

}

```



```java

<p th:text="${#request.getAttribute('request')}"></p>

<p th:text="${#session.getAttribute('session')}"></p>

<p th:text="${#locale.country}"></p>

```


内嵌对象

可以直接通过#访问

dates:java.util.Date的功能和方法

calendars:java.util.Calendar的功能方法

number:格式化数字

String :java.lang.String的功能方法

object:Object的功能和方法

bools:对布尔求值的方法

arrays:操作数组的功能方法

lists:操作集合的功能方法

set:操作集合的功能方法

maps:操作集合的功能方法


```java

@GetMapping("/util")

public String util(Model model){

   model.addAttribute("name","zhangshan");

   model.addAttribute("users",new ArrayList<>());

   model.addAttribute("count",22);

   model.addAttribute("date",new Date());

   return "test";


}

```



```java

<!--    格式化时间-->

   <p th:text="${#dates.format(date,'yyy-MM-dd HH:mm:sss')}"></p>

<!--    创建当前时间,精确到天数-->

   <p th:text="${#dates.createToday()}"></p>

<!--创建当前时间,精确到秒-->

   <p th:text="${#dates.createNow()}"></p>

<!--判断是否为空-->

   <p th:text="${#strings.isEmpty(name)}"></p>

<!--判断List是否为空-->

   <p th:text="${#lists.isEmpty(users)}"></p>

<!--输出字符串长度-->

   <p th:text="${#strings.length(name)}"></p>

<!--拼接字符串-->

   <p th:text="${#strings.concat(name,name,name)}"></p>

<!--创建自定义的字符串-->

   <p th:text="${#strings.randomAlphanumeric(count)}"></p>

```




目录结构

![在这里插入图片描述](https://ucc.alicdn.com/images/user-upload-01/20200530152324160.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3FxXzQ0OTY5NjQz,size_16,color_FFFFFF,t_70)

**Spring boot 数据校验**


```java

@GetMapping("/validator")

public void validatorUser(@Valid User user, BindingResult bindingResult){

   System.out.println(user);

   if(bindingResult.hasErrors())

   {

       List<ObjectError>list=bindingResult.getAllErrors();

       for (ObjectError objectError:list)

       {

           System.out.println(objectError.getCode()+"-"+objectError.getDefaultMessage());

       }

   }

}

```


```java

package com.shuang.entity;


import lombok.Data;

import org.hibernate.validator.constraints.Length;


import javax.validation.constraints.Min;

import javax.validation.constraints.NotEmpty;

import javax.validation.constraints.NotNull;


@Data

public class User {

   @NotNull(message="id不能为空")

   private Long id;

   @NotEmpty(message="姓名不能为空")

   @Length(min=2,message="姓名长度不能小于2位")

   private String name;

   @Min(value=16,message = "年龄必须大于16")

   private int age;

}

```

目录
相关文章
|
JSON JavaScript 数据可视化
SpringBoot+Thymeleaf+ECharts实现大数据可视化(基础篇)
SpringBoot+Thymeleaf+ECharts实现大数据可视化(基础篇)
1088 0
SpringBoot+Thymeleaf+ECharts实现大数据可视化(基础篇)
|
缓存 JavaScript 前端开发
SpringBoot——Thymeleaf中的th:inline(内敛文本text、内敛脚本javascript)
SpringBoot——Thymeleaf中的th:inline(内敛文本text、内敛脚本javascript)
2307 0
SpringBoot——Thymeleaf中的th:inline(内敛文本text、内敛脚本javascript)
|
缓存 编解码 移动开发
SpringBoot 整合 Thymeleaf|学习笔记
快速学习 SpringBoot 整合 Thymeleaf
184 0
SpringBoot 整合 Thymeleaf|学习笔记
|
安全 前端开发 Java
狂神说SpringBoot:SpringSecurity笔记及thymeleaf静态资源(三)
狂神说SpringBoot:SpringSecurity笔记及thymeleaf静态资源(三)
188 0
狂神说SpringBoot:SpringSecurity笔记及thymeleaf静态资源(三)
|
移动开发 安全 前端开发
狂神说SpringBoot:SpringSecurity笔记及thymeleaf静态资源(二)
狂神说SpringBoot:SpringSecurity笔记及thymeleaf静态资源(二)
310 0
狂神说SpringBoot:SpringSecurity笔记及thymeleaf静态资源(二)
|
消息中间件 JSON 前端开发
SpringBoot2.x系列教程08--SpringBoot中整合Thymeleaf动态模板
前言 在前面的章节中,壹哥 带各位利用SpringBoot实现了SSM整合,发现现在SSM整合变得的非常简单,通过几个配置就能搭建出一个项目开发环境。但是在之前的案例中,我们并没有提供UI界面,那么在SpringBoot中如何整合UI界面呢?使用JSP展示页面,还是用HTML展示页面,或者还有其他方案? 在今天的内容里,壹哥 会带大家学习如何在SpringBoot中展示UI界面,这样大家以后就可以把数据信息在页面上渲染展示了。 一. Web开发方式简介 SpringBoot作为一个简化项目开发的利器,其实它为我们提供了一套完整的Web开发方案,从前端到后端,再到数据库、定时任务、消息队列等都
294 0
|
开发框架 安全 Java
狂神说SpringBoot:SpringSecurity笔记及thymeleaf静态资源(一)
狂神说SpringBoot:SpringSecurity笔记及thymeleaf静态资源(一)
516 0
|
Dubbo Java 应用服务中间件
SpringBoot——借助Maven多模块管理实现集成SSM、Dubbo、Thymeleaf的汇总案例
SpringBoot——借助Maven多模块管理实现集成SSM、Dubbo、Thymeleaf的汇总案例
SpringBoot——借助Maven多模块管理实现集成SSM、Dubbo、Thymeleaf的汇总案例
SpringBoot——Thymeleaf中的表达式基本对象、表达式功能对象
SpringBoot——Thymeleaf中的表达式基本对象、表达式功能对象
SpringBoot——Thymeleaf中的表达式基本对象、表达式功能对象
|
缓存 Java
SpringBoot——Thymeleaf中的四种字面量(文本、数字、布尔、null)、字符串拼接、运算符
SpringBoot——Thymeleaf中的四种字面量(文本、数字、布尔、null)、字符串拼接、运算符
SpringBoot——Thymeleaf中的四种字面量(文本、数字、布尔、null)、字符串拼接、运算符