Spring Boot中的模板引擎选择与配置

简介: Spring Boot中的模板引擎选择与配置

Spring Boot中的模板引擎选择与配置


今天我们来聊聊Spring Boot中的模板引擎选择与配置。模板引擎是生成动态网页的关键组件,在Spring Boot中,我们有多种模板引擎可以选择,如Thymeleaf、FreeMarker和Mustache。本文将介绍这些模板引擎的基本特点,并提供配置示例,帮助你快速上手。


一、模板引擎概述


模板引擎用于将数据与模板结合,生成动态的HTML内容。在Spring Boot中,常用的模板引擎包括:

  • Thymeleaf:功能强大,语法简洁,支持Spring EL(表达式语言),与Spring Boot集成良好。
  • FreeMarker:高度可定制,支持复杂的数据处理,适合生成复杂的动态内容。
  • Mustache:轻量级,语法简单,逻辑与视图分离,适合需要简单模板的应用。


二、Thymeleaf的配置与使用


Thymeleaf是Spring Boot默认推荐的模板引擎,配置简单,功能强大。以下是Thymeleaf的配置与使用示例:

  1. 添加依赖

pom.xml中添加Thymeleaf依赖:

<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-thymeleaf</artifactId>
</dependency>
  1. 配置模板路径

application.properties中配置模板路径:

spring.thymeleaf.prefix=classpath:/templates/
spring.thymeleaf.suffix=.html
  1. 创建Controller

创建一个简单的Controller,返回视图:

package cn.juwatech.controller;
import org.springframework.stereotype.Controller;
import org.springframework.ui.Model;
import org.springframework.web.bind.annotation.GetMapping;
@Controller
public class HomeController {
    @GetMapping("/home")
    public String home(Model model) {
        model.addAttribute("message", "欢迎使用Thymeleaf模板引擎!");
        return "home";
    }
}
  1. 创建模板

src/main/resources/templates目录下创建home.html

<!DOCTYPE html>
<html xmlns:th="http://www.thymeleaf.org">
<head>
    <title>Home</title>
</head>
<body>
    <h1 th:text="${message}">Thymeleaf 模板引擎</h1>
</body>
</html>

访问/home路径即可看到动态生成的内容。


三、FreeMarker的配置与使用


FreeMarker是另一款流行的模板引擎,适合处理复杂的模板需求。以下是FreeMarker的配置与使用示例:

  1. 添加依赖

pom.xml中添加FreeMarker依赖:

<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-freemarker</artifactId>
</dependency>
  1. 配置模板路径

application.properties中配置模板路径:

spring.freemarker.template-loader-path=classpath:/templates/
spring.freemarker.suffix=.ftl
  1. 创建Controller

创建一个简单的Controller,返回视图:

package cn.juwatech.controller;
import org.springframework.stereotype.Controller;
import org.springframework.ui.Model;
import org.springframework.web.bind.annotation.GetMapping;
@Controller
public class FreeMarkerController {
    @GetMapping("/freemarker")
    public String freemarker(Model model) {
        model.addAttribute("message", "欢迎使用FreeMarker模板引擎!");
        return "freemarker";
    }
}
  1. 创建模板

src/main/resources/templates目录下创建freemarker.ftl

<!DOCTYPE html>
<html>
<head>
    <title>FreeMarker</title>
</head>
<body>
    <h1>${message}</h1>
</body>
</html>

访问/freemarker路径即可看到动态生成的内容。


四、Mustache的配置与使用


Mustache是一款轻量级的模板引擎,适合需要简单模板的应用。以下是Mustache的配置与使用示例:

  1. 添加依赖

pom.xml中添加Mustache依赖:

<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-mustache</artifactId>
</dependency>
  1. 配置模板路径

application.properties中配置模板路径:

spring.mustache.prefix=classpath:/templates/
spring.mustache.suffix=.mustache
  1. 创建Controller

创建一个简单的Controller,返回视图:

package cn.juwatech.controller;
import org.springframework.stereotype.Controller;
import org.springframework.ui.Model;
import org.springframework.web.bind.annotation.GetMapping;
@Controller
public class MustacheController {
    @GetMapping("/mustache")
    public String mustache(Model model) {
        model.addAttribute("message", "欢迎使用Mustache模板引擎!");
        return "mustache";
    }
}
  1. 创建模板

src/main/resources/templates目录下创建mustache.mustache

<!DOCTYPE html>
<html>
<head>
    <title>Mustache</title>
</head>
<body>
    <h1>{{message}}</h1>
</body>
</html>

访问/mustache路径即可看到动态生成的内容。


五、模板引擎的选择


选择合适的模板引擎取决于具体的项目需求:

  • 如果需要与Spring Boot紧密集成,推荐使用Thymeleaf。
  • 如果需要高度定制和复杂的数据处理,推荐使用FreeMarker。
  • 如果需要轻量级、简单的模板,推荐使用Mustache。

每种模板引擎都有其优点和适用场景,根据项目的具体需求进行选择和配置,才能更好地发挥它们的优势。


六、总结


本文介绍了Spring Boot中常用的三种模板引擎:Thymeleaf、FreeMarker和Mustache,并提供了详细的配置和使用示例。通过这些示例,大家可以快速上手并在项目中灵活使用不同的模板引擎。希望本文能帮助你在Spring Boot项目中更好地进行模板引擎的选择与配置。

相关文章
|
9天前
|
Java Spring
【Spring】方法注解@Bean,配置类扫描路径
@Bean方法注解,如何在同一个类下面定义多个Bean对象,配置扫描路径
136 73
|
2月前
|
Java 开发者 微服务
手写模拟Spring Boot自动配置功能
【11月更文挑战第19天】随着微服务架构的兴起,Spring Boot作为一种快速开发框架,因其简化了Spring应用的初始搭建和开发过程,受到了广大开发者的青睐。自动配置作为Spring Boot的核心特性之一,大大减少了手动配置的工作量,提高了开发效率。
68 0
|
3月前
|
Java API 数据库
构建RESTful API已经成为现代Web开发的标准做法之一。Spring Boot框架因其简洁的配置、快速的启动特性及丰富的功能集而备受开发者青睐。
【10月更文挑战第11天】本文介绍如何使用Spring Boot构建在线图书管理系统的RESTful API。通过创建Spring Boot项目,定义`Book`实体类、`BookRepository`接口和`BookService`服务类,最后实现`BookController`控制器来处理HTTP请求,展示了从基础环境搭建到API测试的完整过程。
63 4
|
3月前
|
Java API 数据库
Spring Boot框架因其简洁的配置、快速的启动特性及丰富的功能集而备受开发者青睐
本文通过在线图书管理系统案例,详细介绍如何使用Spring Boot构建RESTful API。从项目基础环境搭建、实体类与数据访问层定义,到业务逻辑实现和控制器编写,逐步展示了Spring Boot的简洁配置和强大功能。最后,通过Postman测试API,并介绍了如何添加安全性和异常处理,确保API的稳定性和安全性。
58 0
|
1天前
|
移动开发 前端开发 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 等属性,可以抽取和复用公共页面片段,并支持参数传递。
28 12
|
9天前
|
Java Spring
【Spring配置相关】启动类为Current File,如何更改
问题场景:当我们切换类的界面的时候,重新启动的按钮是灰色的,不能使用,并且只有一个Current File 项目,下面介绍两种方法来解决这个问题。
|
9天前
|
Java Spring
【Spring配置】idea编码格式导致注解汉字无法保存
问题一:对于同一个项目,我们在使用idea的过程中,使用汉字注解完后,再打开该项目,汉字变成乱码问题二:本来a项目中,汉字注解调试好了,没有乱码了,但是创建出来的新的项目,写的注解又成乱码了。
|
9天前
|
Java Spring
【Spring配置】创建yml文件和properties或yml文件没有绿叶
本文主要针对,一个项目中怎么创建yml和properties两种不同文件,进行配置,和启动类没有绿叶标识进行解决。
|
17天前
|
NoSQL Java Redis
Spring Boot 自动配置机制:从原理到自定义
Spring Boot 的自动配置机制通过 `spring.factories` 文件和 `@EnableAutoConfiguration` 注解,根据类路径中的依赖和条件注解自动配置所需的 Bean,大大简化了开发过程。本文深入探讨了自动配置的原理、条件化配置、自定义自动配置以及实际应用案例,帮助开发者更好地理解和利用这一强大特性。
67 14
|
14天前
|
XML Java 数据格式
Spring容器Bean之XML配置方式
通过对以上内容的掌握,开发人员可以灵活地使用Spring的XML配置方式来管理应用程序的Bean,提高代码的模块化和可维护性。
52 6