Springboot整合Thymeleaf并详解热部署

简介: thymeleaf

前言

  • Thymeleaf是用来开发Web和独立环境项目的服务器端的Java模版引擎
  • Spring官方支持的服务的渲染模板中,并不包含jsp。而是Thymeleaf和Freemarker等,而Thymeleaf与SpringMVC的视图技术,及SpringBoot的自动化配置集成非常完美,几乎没有任何成本,你只用关注Thymeleaf的语法即可。
  • Thymeleaf支持html原型,浏览器解释 html 时会忽略未定义的标签属性,所以 thymeleaf 的模板可以静态地运行;当有数据返回到页面时,Thymeleaf 标签会动态地替换掉静态内容,使页面动态显示

POM.XML

这里添加了spring-boot-devtools来使Spring Boot应用支持热部署

<dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web</artifactId></dependency><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-devtools</artifactId><optional>true</optional><!-- 这个需要为 true 热部署才有效 --></dependency><!-- spring-boot-starter-thymeleaf --><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-thymeleaf</artifactId><version>2.2.2.RELEASE</version></dependency>

image.gif

可以看一下SpringBoot自动配置的路径

image.gif1.png

说明:

(1) devtools可以实现页面热部署(即页面修改后会立即生效,这个可以直接在application.properties文件中配置spring.thymeleaf.cache=false来实现),实现类文件热部署(类文件修改后不会立即生效),实现对属性文件的热部署。

即devtools会监听classpath下的文件变动,并且会立即重启应用(发生在保存时机),注意:因为其采用的虚拟机机制,该项重启是很快的

(2)配置了true后在修改java文件后也就支持了热启动,不过这种方式是属于项目重启(速度比较快的项目重启),会清空session中的值,也就是如果有用户登陆的话,项目重启后需要重新登陆。默认情况下,/META-INF/maven/META-INF/resources/resources/static/templates/public这些文件夹下的文件修改不会使应用重启,但是会重新加载(devtools内嵌了一个LiveReload server,当资源发生改变时,浏览器刷新)。

application.properties

#thymeleaf 配置
spring.thymeleaf.mode=HTML5
spring.thymeleaf.encoding=UTF-8
spring.thymeleaf.servlet.content-type=text/html
#缓存设置为false, 这样修改之后马上生效,便于调试
spring.thymeleaf.cache=false
#设置重启的目录
#spring.devtools.restart.additional-paths: src/main/java
#classpath目录下的文件夹内容修改不重启
#spring.devtools.restart.exclude: static/**
#上下文
#server.context-path=/thymeleaf

image.gif

IDEA设置

当我们修改了Java类后,IDEA默认是不自动编译的,而spring-boot-devtools又是监测classpath下的文件发生变化才会重启应用,所以需要设置IDEA的自动编译:

(1)File-Settings-Compiler-Build Project automatically

image.gif2.png

(2)ctrl + shift + alt + /,选择Registry,勾上 Compiler autoMake allow when app running

image.gif3.png

此时实现的效果就是:修改类和配置文件应用会重启,修改页面应用不会重启,但会重新加载,页面会刷新。

通常情况下我不希望一修改它就重启,所以不使用自动编译,而是手动使用Ctrl+F9来重新编译

测试ThymeLeaf

首先在templates下新建index.html页面,如果没有templates文件夹就自己新建一个

index.html:

<!DOCTYPEhtml><htmllang="en"xmlns:th="http://www.w3.org/1999/xhtml"><head><metacharset="UTF-8"><title>首页</title></head><body><pth:text="${tips}"></p></body></html>

image.gif

controller:

@Controller@RequestMapping("/indexManage")
publicclassIndexController {
@RequestMapping("/toIndex")
publicStringtoIndex(Modelmodel){
model.addAttribute("tips","Hello Thymeleaf");
return"index";
    }
}

image.gif

访问:http://localhost:8080/indexManage/toIndex

image.gif4.png

扩展:Thymeleaf其他用法

    • thymeleaf引入js、css文件:
    <scripttype="text/javascript"src="../js/jquery.js"th:src="@{../js/jquery.js}"></script>

    image.gif

    使用 @这种方式引入,在渲染后的html 里会自动生成 上下文路径,此demo没有上下文路径。

    如果使用浏览器直接打开当前的 hello.html, 依然可以看到css 和 js 效果,因为前面正常的src语句会起作用

    image.gif5.png

      • 几种常用的语法

      1、获取对象的属性值

       新建POJO

      publicclassStudent {
      privateIntegerid;
      privateStringsname;
      privateIntegerage;
      getter...  setter...
      }

      image.gif

      修改Controller:

      @Controller@RequestMapping("/indexManage")
      publicclassIndexController {
      @RequestMapping("/toIndex")
      publicStringtoIndex(Modelmodel){
      Studentstudent=newStudent();
      student.setSname("亚瑟");
      model.addAttribute("student",student);
      return"index";
          }
      }

      image.gif

      在页面中获取对象的属性值

      你好!<pth:text="${student.sname}"></p>

      image.gif

      image.gif6.png

      2、包含其他页面

      th:fragment   th:replace

      新建include.html

      <!DOCTYPEhtml><htmllang="en"xmlns:th="http://www.w3.org/1999/xhtml"><head><metacharset="UTF-8"><title>Title</title></head><body><footerth:fragment="footerOne">Copyright</footer><footerth:fragment="footerTwo(start,end)"><pth:text="|${start} - ${end} All Rights Reserved|"></p></footer></body></html>

      image.gif

      在index页面使用

      <div><divth:replace="include::footerOne"></div><divth:replace="include::footerTwo(2014,2020)"></div></div>

      image.gif

      image.gif7.png

      3、条件判断 th:if

      Thymeleaf 的条件判断是 通过 th:if 来做的,只有为真的时候,才会显示当前元素

      在model中添加一个boolean数据

      booleanflag=true;
      model.addAttribute("flag",flag);

      image.gif

      在index页面中外层div使用:

      <divth:if="${flag}"><divth:replace="include::footerOne"></div><divth:replace="include::footerTwo(2014,2020)"></div></div>

      image.gif

      取反可以用th:if="${not flag}, 或者用th:unless="${flag}

      不只是布尔值的 true 和 false, th:if 表达式返回其他值时也会被认为是 true 或 false,规则如下:

      boolean 类型并且值是 true, 返回 true

      数值类型并且值不是 0, 返回 true

      字符类型(Char)并且值不是 0, 返回 true

      String 类型并且值不是 "false", "off", "no", 返回 true

      不是 boolean, 数值, 字符, String 的其他类型, 返回 true

      值是 null, 返回 false

      4、th:each 遍历

      修改controller    记得在Student中添加构造方法

      @RequestMapping("/toIndex")
      publicStringtoIndex(Modelmodel){
      List<Student>students=newArrayList<>();
      students.add(newStudent(1,"张三",16));
      students.add(newStudent(2,"李四",17));
      students.add(newStudent(3,"王五",18));
      model.addAttribute("students",students);
      return"index";
          }

      image.gif

      index页面:

      <table><thead><tr><th>id</th><th>姓名</th><th>年龄</th></tr></thead><tbody><trth:each="student: ${students}"><tdth:text="${student.id}"></td><tdth:text="${student.sname}"></td><tdth:text="${student.age}"></td></tr></tbody></table>

      image.gif

      image.gif8.png

      相关文章
      |
      XML 缓存 前端开发
      Thymeleaf一篇就够了
      Thymeleaf是Springboot官方支持的模板引擎,有着动静分离等独有特点,通过本文简单学习下吧!
      62268 24
      Thymeleaf一篇就够了
      |
      监控 druid Java
      Spring Boot 3 集成 Druid 连接池详解
      在现代的Java应用中,使用一个高效可靠的数据源是至关重要的。Druid连接池作为一款强大的数据库连接池,提供了丰富的监控和管理功能,成为很多Java项目的首选。本文将详细介绍如何在Spring Boot 3项目中配置数据源,集成Druid连接池,以实现更高效的数据库连接管理。
      8978 2
      Spring Boot 3 集成 Druid 连接池详解
      |
      8月前
      |
      移动开发 前端开发 JavaScript
      SpringBoot3 整合Thymeleaf 模板引擎
      Thymeleaf 是一个基于 Java 的现代模板引擎,支持 HTML 原型,文件后缀为 .html,可直接在浏览器中查看静态效果。它与 Spring Boot 完美整合,默认配置即可使用,无需额外视图解析器设置。Thymeleaf 支持多种表达式(如变量、链接、国际化等)和 th 属性(如 th:text、th:if 等),适用于 Web 和非 Web 应用开发。通过 th:fragment、th:insert、th:replace 和 th:include 等属性,可以抽取和复用公共页面片段,并支持参数传递。
      1038 12
      |
      5月前
      |
      缓存 Java Spring
      IDEA中配置HTML和Thymeleaf热部署的步骤
      以上就是在IntelliJ IDEA中配置HTML和Thymeleaf热部署的步骤。这样的配置可以大大提高你的开发效率,让你更专注于代码的编写,而不是等待应用的重启。希望这个指南对你有所帮助!
      334 21
      |
      10月前
      |
      缓存 IDE Java
      SpringBoot入门(7)- 配置热部署devtools工具
      SpringBoot入门(7)- 配置热部署devtools工具
      977 1
      SpringBoot入门(7)- 配置热部署devtools工具
      |
      12月前
      |
      Java Spring
      springboot静态资源目录访问,及自定义静态资源路径,index页面的访问
      本文介绍了Spring Boot中静态资源的访问位置、如何进行静态资源访问测试、自定义静态资源路径和静态资源请求映射,以及如何处理自定义静态资源映射对index页面访问的影响。提供了两种解决方案:取消自定义静态资源映射或编写Controller来截获index.html的请求并重定向。
      springboot静态资源目录访问,及自定义静态资源路径,index页面的访问
      |
      前端开发 Java Spring
      springboot+thymeleaf+bootstrap 超级无敌简洁的页面展示 商城管理页面
      这篇文章展示了一个使用Spring Boot、Thymeleaf和Bootstrap框架开发的简洁、响应式的商城管理页面,包括美食介绍、产品详情、购物车等功能,适合初学者学习和使用。
      springboot+thymeleaf+bootstrap 超级无敌简洁的页面展示 商城管理页面
      |
      12月前
      |
      Java 网络架构
      springboot配合thymeleaf,调用接口不跳转页面只显示文本
      springboot配合thymeleaf,调用接口不跳转页面只显示文本
      477 0
      |
      容器
      Thymeleaf内置对象与工具类【详解版】
      Thymeleaf 3.0 提供了七大内置对象,包括${#ctx}(上下文对象)、${#param}(参数变量)、${#locale}(区域语言设置)、${#request}(HttpServletRequest)、${#response}(HttpServletResponse)、${#session}(HttpSession)和${#servletContext}(ServletContext)。示例代码展示了如何在后端传递不同对象容器中的参数到Thymeleaf模板。
      436 0
      |
      Java Spring
      springboot项目读取 resources 目录下的文件的9种方式(总结)
      springboot项目读取 resources 目录下的文件的9种方式(总结)
      5833 1