详细介绍:Java-Spring入门指南(十九)thymeleaf基本概念

news/2025/10/16 20:38:24/文章来源:https://www.cnblogs.com/wzzkaifa/p/19146579

Java-Spring入门指南(十九)thymeleaf基本概念

  • 前言
  • 一、thymeleaf是什么,有什么用,作用是什么?
    • 什么?就是1.1 Thymeleaf
      • 核心特征总结
    • 1.2 Thymeleaf有什么用?
      • 对比JSP:Thymeleaf的核心优势
      • 实际开发中的使用场景
    • 1.3 Thymeleaf的核心作用是什么?
      • (1)数据绑定:将后端数据嵌入HTML
      • (2)逻辑控制:实现页面动态逻辑
      • (3)格式转换:统一素材显示格式
      • (4)资源引入:动态加载CSS/JS/图片

前言

  • 在上一篇博客中,我们掌握了SpringMVC中JSON的解析与项目间数据交互,解决了“后端如何传递数据给前端”的障碍,但前端接收数据后,如何优雅地渲染页面仍是关键——传统JSP虽能实现视图渲染,但存在依赖Servlet容器、无法静态预览、语法冗余等局限性,尤其在前后端协作场景中效率较低。
  • Thymeleaf正是为解决这些问题而生的模板引擎,它是Spring官方推荐的视图层技术(替代JSP),能在无Servlet容器的环境下直接预览HTML页面,还能利用简洁的语法实现内容绑定、逻辑控制等能力,完美适配SpringMVC的视图需求。
  • 本文作为Thymeleaf的入门概念篇,将聚焦“是什么、有什么用、核心作用”三大核心问题,为下一篇的代码实战(第二十篇)做好理论铺垫;所有内容仍基于我们熟悉的Maven+IDEA+Tomcat 11环境,确保学习连贯性。

我的个人主页,欢迎来阅读我的其他文章
https://blog.csdn.net/2402_83322742?spm=1011.2415.3001.5343
我的Java-Spring入门指南知识文章专栏
欢迎来阅读指出不足
https://blog.csdn.net/2402_83322742/category_13040333.html?spm=1001.2014.3001.5482

在这里插入图片描述


thymeleaf官方中文文档地址
https://www.wuzao.com/thymeleaf/documentation.html

一、thymeleaf是什么,有什么用,作用是什么?

Thymeleaf的核心定位是“面向Web和独立环境的现代服务器端Java模板引擎”,它不仅能渲染HTML,还支持XML、TEXT、JavaScript等格式,但在SpringMVC中,我们主要用它来处理HTML视图,解决传统JSP的痛点。

1.1 Thymeleaf是什么?

一款“就是Thymeleaf本质能嵌入动态数据的HTML模板引擎”,它通过自定义的标签属性(如th:text)将后端传递的Java数据(如User对象、List列表)嵌入到HTML页面中,最终生成用户看到的动态页面。

它最核心的特性是“天然支持HTML它区别于JSP的关键:就是”,这也

核心特征总结

  • 无容器依赖:不依赖Tomcat等Servlet容器,静态HTML即可预览,降低前后端协作成本。
  • 语法自然:动态逻辑通过th:*属性嵌入HTML,不破坏HTML原有结构,代码可读性高。
  • Spring官方推荐:Spring Boot和Spring MVC均将其作为默认视图引擎,无需繁琐配置即可集成。
  • 功能全面:支持数据绑定、循环遍历、条件判断、日期格式化、资源引入等所有视图层所需能力。

1.2 Thymeleaf有什么用?

在Thymeleaf出现前,JSP是Java Web任务的主流视图技术,但JSP的局限性在前后端分离和快速迭代场景中越来越明显。Thymeleaf的价值,正是通过应对这些痛点提升构建效率。

对比JSP:Thymeleaf的核心优势

对比维度传统JSPThymeleaf
静态预览不支持,直接打开显示<% %>乱码支持,静态HTML显示默认值,动态数据不影响预览
容器依赖依赖Servlet容器(如Tomcat)才能解析无依赖,纯HTML文件即可编辑预览
语法简洁性需混合<% %>、EL表达式,语法繁琐统一用th:*属性,语法简洁易记
前后端协作困难(前端需熟悉JSP语法)简单(前端写纯HTML,后端加th:*属性)
Spring生态适配需额外配置(如视图解析器)官方推荐,Spring Boot自动配置

实际开发中的运用场景

1.3 Thymeleaf的核心作用是什么?

Thymeleaf作为SpringMVC的视图引擎,核心作用是“接收后端传递的数据,动态生成HTML页面”,具体可拆解为4个核心功能,这些功能将在第二十篇代码实战中详细演示:

(1)数据绑定:将后端素材嵌入HTML

这是Thymeleaf最基础的作用,通过th:textth:value等属性,将后端Model中的数据(如model.addAttribute("username", "zhangsan"))显示在HTML页面中。

(2)逻辑控制:达成页面动态逻辑

支持条件判断(th:if/th:unless)、循环遍历(th:each)等逻辑,无需写Java代码,直接在HTML中通过属性实现。

  • 循环示例:后端传递List<User> userList,前端通过<tr th:each="user : ${userList}">遍历列表,动态生成表格行。
  • 条件示例:通过<div th:if="${user.age > 18}">成年</div>,根据用户年龄动态显示不同内容。

(3)格式转换:统一数据显示格式

内置日期、数字、字符串等格式转换器,无需后端手动处理格式,直接在前端通过th:format或相关属性配置。

(4)资源引入:动态加载CSS/JS/图片

通过th:hrefth:src等属性,动态引入CSS、JavaScript、图片等静态资源,避免硬编码路径(尤其在项目部署路径变化时,无需修改资源路径)。

  • 示例:<link rel="stylesheet" th:href="@{/css/style.css}" href="/css/style.css">,静态预览时用href加载本地CSS,动态渲染时用th:href加载项目部署后的CSS。

下一篇将带来Thymeleaf的代码实战(依赖导入、配置、数据绑定与逻辑控制)


我的个人主页,欢迎来阅读我的其他文章
https://blog.csdn.net/2402_83322742?spm=1011.2415.3001.5343
我的Java-Spring入门指南知识文章专栏
欢迎来阅读指出不足
https://blog.csdn.net/2402_83322742/category_13040333.html?spm=1001.2014.3001.5482

非常感谢您的阅读,喜欢的话记得三连哦

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/938496.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

P2605 [ZJOI2010] 基站选址

题目概述 题目链接:https://www.luogu.com.cn/problem/P2605。 有 \(n\) 个村庄,你需要建立不超过 \(k\) 个基站,每一户人家都有参数 \(d_i,s_i,w_i,c_i\) 分别表示距离第一户人家的距离、在不超过 \(s_i\) 的地方有…

NVIDIA Jetson AGX Xavier刷机教程

NVIDIA Jetson AGX Xavier刷机教程 @目录NVIDIA Jetson AGX Xavier刷机教程1.下载SdkManager2.安装SdkManager3.刷机 1.下载SdkManager 进入SdkManager官网下载SdkManager的deb版本 注意,ubuntu的24.04版本暂时不支持…

洛谷p1462-通往奥格瑞码道路

题目:https://www.luogu.com.cn/problem/P1462 思考过程: 刚拿到这个题,我把消耗的血量和路费当成了负权边去考虑,考虑到我们只需要考虑扣钱的最优,并且在血量扣尽之前达到就好,那我觉得可以用一个数组hp来代表实…

详细介绍:VR 太阳光参数与快速渲染

详细介绍:VR 太阳光参数与快速渲染pre { white-space: pre !important; word-wrap: normal !important; overflow-x: auto !important; display: block !important; font-family: "Consolas", "Monaco…

位运算中没用的小技巧

位运算那些没用的小技巧消去最后一位的1 x & (x - 1)交换两个数 a ^= b; b ^= a; a ^= b;检查一个数的奇偶 x & 1求x的绝对值 ~(x >> 31) ? a : ~a + 1取两个数的最大值 x ^ ((x ^ y) & -(x < y…

超越基础:SightAI 智能路由与多模型选择实战 - sight

在第一周的入门指南中,我们已经学会了如何使用 SightAI 的基础 API 调用,实现了一个简单的对话交互。不少开发者会面临新的需求:想降低推理成本时,如何找到性价比更高的模型?追求交互速度时,怎样获取更快的响应?…

kafka连接认证

kafka连接认证明白,我帮你整理一份 Kafka 客户端三阶段检查完整文档,涵盖原理、检查目的、可能异常、排查方法以及你之前脚本逻辑对应的解释。文档形式清晰,方便阅读和运维参考。Kafka 客户端三阶段连接检查完整文档…

[Vulhub靶机]JARBAS靶机渗透

[Vulhub靶机]JARBAS靶机渗透 靶机搭建 下载地址: https://download.vulnhub.com/jarbas/Jarbas.zip 下载后设置nat模式即可与攻击机同一网段 kali:192.168.88.1331.信息收集 主机发现 首先对C段进行扫描,发现131这台主…

CF622D 题解

很好的一道思维题。 容易发现答案下界是 \(0\),手模几组发现好像都能取到,考虑能不能找到构造答案为 \(0\) 的通解。 那么除了 \(i=n\) 以外的所有 \(i\) 都应该有 \(d_i=n-i\),考虑构造这个东西,然后最后 \(n\) 随…

vue学习的总结

vue学习如何判断vue框架: (1)使用插件(最无脑的) (2)判断是否有id为app的div (3)判断站点是否只有一个index.html (4)可以用findVueRoot函数 (5)使用油猴的脚本进行清除路由若能清除也可以判断为vue(油猴…

最小二乘问题详解5:非线性最小二乘求解实例

通过拟合非线性函数的实例,详细讲解了非线性最小二乘问题中Gauss-Newton方法的实现过程,并给出了基于Eigen库的C++代码示例及收敛分析。1. 引言 在上一篇文章《最小二乘问题详解4:非线性最小二乘》中,介绍了非线性…

【28】C# WinForm入门到精通 ——多文档窗体MDI【属性、强大的方法、实例、源码】【多窗口重叠、水平平铺、垂直平铺、窗体传值】

【28】C# WinForm入门到精通 ——多文档窗体MDI【属性、强大的方法、实例、源码】【多窗口重叠、水平平铺、垂直平铺、窗体传值】pre { white-space: pre !important; word-wrap: normal !important; overflow-x: auto…

第五周预习

20231313 张景云《密码系统设计》第五周预习AI对内容的总结 Windows.C.C++.加密解密实战.sm.ys 一、数字签名技术基础背景与意义:互联网信息安全问题突出,如网站篡改、仿冒页面等,数字签名技术作为基于密码学的安全…

2025 非标门/铸铝门/别墅大门厂家推荐榜:聚焦品质与服务的实力之选

在建筑建材领域,门作为空间防护与装饰的核心载体,其品质直接关系到居住安全与生活体验。市面上门业厂商众多,产品性能与服务质量参差不齐。基于技术实力、产品适配性、市场口碑等多维度考量,本文筛选出五家各具优势…

工业数字化未来:IT与OT融合实践

本文探讨数字技术在工业与运营环境中的实际应用,包括远程诊断系统、统一登录平台和跨设备协作解决方案,分析如何通过优化数字员工体验提升生产力与安全性,并介绍多家机构在IT与OT融合过程中的实践经验。工业运营工作…

AI安全新威胁:提示注入与模型中毒攻击深度解析

本文深入探讨AI安全领域两大新兴威胁:提示注入与模型中毒攻击。详细分析直接注入、间接注入、多模态注入等攻击技术,以及数据投毒、后门植入等模型威胁,为企业安全团队提供全面的防御策略和实战案例。提示注入与模型…

神经网络入门研读报告

神经网络入门研读报告:基于数据驱动的机器认知模型 神经网络是一种模拟生物神经系统信息处理机制的机器学习模型,核心功能是通过多层非线性变换,从结构化或非结构化数据中自动学习特征与规律,实现分类、预测等认知…

阅读《记录一类分治方法》笔记

目前只有题一。阅读《记录一类分治方法》笔记 题一 \(n\) 个点的无向图,边有边权。\(q\) 次操作,每次操作是添加/删除一条边、修改一条边的边权、查询最小生成树这四种之一。 前言 其实只看了题一,后面都还没看呢。…

CF2140E2

给定 \(n(1 \le n\le 20), m(1 \le m \le 10^6)\) 和一些 \(p_i\)。有 \(n\) 堆石子,每堆石子有 \(1 \sim m\) 个。两个人进行博弈,每次每个人可以取走第 \(p_i\) 堆石子(\(i\) 任选),然后剩下的石堆重新编号,直…

Codeforces 380E Sereja and Dividing 题解 [ 紫 ] [ 线段树 ] [ 贪心 ] [ 数学 ]

Sereja and Dividing:一年前的模拟赛就能秒这个 *2600 了,可我现在怎么还这么菜 /ll/ll/ll。 先考虑当杯子的集合固定时如何选择,显然一个杯子不会被选第二次,并且杯子从大到小选一定是最优的。证明只需要列出最后…