本文由 简悦 SimpRead 转码, 原文地址 blog.csdn.net
Spring Boot 中的模板引擎选择与配置
大家好,我是免费搭建查券返利机器人省钱赚佣金就用微赚淘客系统 3.0 的小编,也是冬天不穿秋裤,天冷也要风度的程序猿!今天我们来聊聊 Spring Boot 中的模板引擎选择与配置。模板引擎是生成动态网页的关键组件,在 Spring Boot 中,我们有多种模板引擎可以选择,如 Thymeleaf、FreeMarker 和 Mustache。本文将介绍这些模板引擎的基本特点,并提供配置示例,帮助你快速上手。
一、模板引擎概述
模板引擎用于将数据与模板结合,生成动态的 HTML 内容。在 Spring Boot 中,常用的模板引擎包括:
- Thymeleaf:功能强大,语法简洁,支持 Spring EL(表达式语言),与 Spring Boot 集成良好。
- FreeMarker:高度可定制,支持复杂的数据处理,适合生成复杂的动态内容。
- Mustache:轻量级,语法简单,逻辑与视图分离,适合需要简单模板的应用。
二、Thymeleaf 的配置与使用
Thymeleaf 是 Spring Boot 默认推荐的模板引擎,配置简单,功能强大。以下是 Thymeleaf 的配置与使用示例:
- 添加依赖
在pom.xml中添加 Thymeleaf 依赖:
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-thymeleaf</artifactId>
</dependency>
- 配置模板路径
在application.properties中配置模板路径:
spring.thymeleaf.prefix=classpath:/templates/
spring.thymeleaf.suffix=.html
- 创建 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";
}
}
- 创建模板
在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 的配置与使用示例:
- 添加依赖
在pom.xml中添加 FreeMarker 依赖:
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-freemarker</artifactId>
</dependency>
- 配置模板路径
在application.properties中配置模板路径:
spring.freemarker.template-loader-path=classpath:/templates/
spring.freemarker.suffix=.ftl
- 创建 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";
}
}
- 创建模板
在src/main/resources/templates目录下创建freemarker.ftl:
<!DOCTYPE html>
<html>
<head>
<title>FreeMarker</title>
</head>
<body>
<h1>${message}</h1>
</body>
</html>
访问/freemarker路径即可看到动态生成的内容。
四、Mustache 的配置与使用
Mustache 是一款轻量级的模板引擎,适合需要简单模板的应用。以下是 Mustache 的配置与使用示例:
- 添加依赖
在pom.xml中添加 Mustache 依赖:
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-mustache</artifactId>
</dependency>
- 配置模板路径
在application.properties中配置模板路径:
spring.mustache.prefix=classpath:/templates/
spring.mustache.suffix=.mustache
- 创建 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";
}
}
- 创建模板
在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 项目中更好地进行模板引擎的选择与配置。