Spring Boot中使用Thymeleaf进行页面渲染

Spring Boot中使用Thymeleaf进行页面渲染

大家好,我是免费搭建查券返利机器人省钱赚佣金就用微赚淘客系统3.0的小编,也是冬天不穿秋裤,天冷也要风度的程序猿!今天我们将探讨如何在Spring Boot应用中使用Thymeleaf模板引擎进行页面渲染,这是构建现代化Web应用不可或缺的一部分。

Spring Boot中使用Thymeleaf进行页面渲染

Thymeleaf是一款优秀的Java模板引擎,特别适合用于构建Spring MVC Web应用。它不仅提供了强大的模板功能,还能与Spring Boot完美集成,使得开发者可以通过简单的标记语言构建动态页面,同时保持良好的可维护性和扩展性。

第一步:配置Spring Boot集成Thymeleaf

添加Thymeleaf依赖

在Spring Boot项目的pom.xml文件中添加Thymeleaf依赖:

xml 复制代码
<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-thymeleaf</artifactId>
</dependency>
配置Thymeleaf模板位置

默认情况下,Thymeleaf会自动查找位于src/main/resources/templates/目录下的HTML模板文件。您可以在application.properties中配置自定义的模板路径:

properties 复制代码
# Thymeleaf模板配置
spring.thymeleaf.prefix=classpath:/templates/
spring.thymeleaf.suffix=.html
spring.thymeleaf.cache=false
创建Thymeleaf模板文件

src/main/resources/templates/目录下创建Thymeleaf模板文件,例如index.html

html 复制代码
<!DOCTYPE html>
<html xmlns:th="http://www.thymeleaf.org">
<head>
    <meta charset="UTF-8">
    <title>Spring Boot Thymeleaf Demo</title>
</head>
<body>
    <h1>Welcome to Spring Boot Thymeleaf Demo</h1>
    <p th:text="'Hello, ' + ${user.name} + '!'" />
</body>
</html>

第二步:在Spring Boot控制器中使用Thymeleaf

编写控制器

创建一个简单的控制器类,处理HTTP请求并返回Thymeleaf模板:

java 复制代码
package cn.juwatech.springbootthymeleaf.controller;

import org.springframework.stereotype.Controller;
import org.springframework.ui.Model;
import org.springframework.web.bind.annotation.GetMapping;
import cn.juwatech.springbootthymeleaf.model.User;

@Controller
public class HomeController {

    @GetMapping("/")
    public String home(Model model) {
        User user = new User("Alice");
        model.addAttribute("user", user);
        return "index";
    }
}
模型数据绑定

在控制器方法中,通过Model对象将数据传递给Thymeleaf模板。在这个例子中,我们创建了一个User对象,并通过${user.name}在模板中显示其名字。

第三步:Thymeleaf模板引擎的标记语言

使用Thymeleaf标签

Thymeleaf提供了丰富的标签和属性,用于动态渲染HTML页面。例如,${user.name}用于显示用户的名字,th:text属性用于在元素内部显示动态文本。

结语

通过本文的介绍,您了解了如何在Spring Boot应用中集成和使用Thymeleaf进行页面渲染。Thymeleaf不仅简化了HTML页面的开发,还提供了强大的模板功能和灵活的扩展性,适合构建现代化的Web应用程序。

相关推荐
土狗TuGou1 天前
SQL内功笔记 · 第8篇:事务的四大特性与隔离级别
数据库·笔记·后端·sql·mysql·oracle
ZengLiangYi1 天前
React Query + REST API 最佳实践
javascript·后端·react.js
星浩AI1 天前
项目实战:合同智能审批 · LangGraph + HITL 人机协同方案 [有源码]
后端·langchain·agent
JavaGuide1 天前
Codex 接入第三方模型 DeepSeek、GLM、Kimi 教程:CC-Switch 和 Codex++ 两种方案对比
后端·ai编程
ZengLiangYi1 天前
Fastify 加 Electron:把 Web 服务嵌进桌面应用
前端·javascript·后端
在繁华处1 天前
Java从零到熟练(九):并发编程基础
java·开发语言
木头程序员1 天前
SSM框架学习笔记
java·开发语言·mysql·spring·maven
李白你好1 天前
页面资产梳理 · 技术指纹识别 · Spring 端点探测
java·后端·spring
用户1753721240331 天前
02《面向对象设计原则:SOLID原则实战解析》
后端
一起逃去看海吧1 天前
dify-03
java·linux·开发语言