立即前往

活动

天翼云最新优惠活动,涵盖免费试用,产品折扣等,助您降本增效!
查看全部活动
热门活动
  • 智算采购季 热销S6云服务器2核4G限时88元/年起,部分主机可加赠对象存储组合包!
  • 免费体验DeepSeek,上天翼云息壤 NEW 新老用户均可免费体验2500万Tokens,限时两周
  • 云上钜惠 HOT 爆款云主机全场特惠,更有万元锦鲤券等你来领!
  • 算力套餐 HOT 让算力触手可及
  • 天翼云脑AOne NEW 连接、保护、办公,All-in-One!
  • 一键部署Llama3大模型学习机 0代码一键部署,预装最新主流大模型Llama3与StableDiffusion
  • 中小企业应用上云专场 产品组合下单即享折上9折起,助力企业快速上云
  • 息壤高校钜惠活动 NEW 天翼云息壤杯高校AI大赛,数款产品享受线上订购超值特惠
  • 天翼云电脑专场 HOT 移动办公新选择,爆款4核8G畅享1年3.5折起,快来抢购!
  • 天翼云奖励推广计划 加入成为云推官,推荐新用户注册下单得现金奖励
免费活动
  • 免费试用中心 HOT 多款云产品免费试用,快来开启云上之旅
  • 天翼云用户体验官 NEW 您的洞察,重塑科技边界

智算服务

打造统一的产品能力,实现算网调度、训练推理、技术架构、资源管理一体化智算服务
智算云(DeepSeek专区)
科研助手
  • 算力商城
  • 应用商城
  • 开发机
  • 并行计算
算力互联调度平台
  • 应用市场
  • 算力市场
  • 算力调度推荐
一站式智算服务平台
  • 模型广场
  • 体验中心
  • 服务接入
智算一体机
  • 智算一体机
大模型
  • DeepSeek-R1-昇腾版(671B)
  • DeepSeek-R1-英伟达版(671B)
  • DeepSeek-V3-昇腾版(671B)
  • DeepSeek-R1-Distill-Llama-70B
  • DeepSeek-R1-Distill-Qwen-32B
  • Qwen2-72B-Instruct
  • StableDiffusion-V2.1
  • TeleChat-12B

应用商城

天翼云精选行业优秀合作伙伴及千余款商品,提供一站式云上应用服务
进入甄选商城进入云市场创新解决方案
办公协同
  • WPS云文档
  • 安全邮箱
  • EMM手机管家
  • 智能商业平台
财务管理
  • 工资条
  • 税务风控云
企业应用
  • 翼信息化运维服务
  • 翼视频云归档解决方案
工业能源
  • 智慧工厂_生产流程管理解决方案
  • 智慧工地
建站工具
  • SSL证书
  • 新域名服务
网络工具
  • 翼云加速
灾备迁移
  • 云管家2.0
  • 翼备份
资源管理
  • 全栈混合云敏捷版(软件)
  • 全栈混合云敏捷版(一体机)
行业应用
  • 翼电子教室
  • 翼智慧显示一体化解决方案

合作伙伴

天翼云携手合作伙伴,共创云上生态,合作共赢
天翼云生态合作中心
  • 天翼云生态合作中心
天翼云渠道合作伙伴
  • 天翼云代理渠道合作伙伴
天翼云服务合作伙伴
  • 天翼云集成商交付能力认证
天翼云应用合作伙伴
  • 天翼云云市场合作伙伴
  • 天翼云甄选商城合作伙伴
天翼云技术合作伙伴
  • 天翼云OpenAPI中心
  • 天翼云EasyCoding平台
天翼云培训认证
  • 天翼云学堂
  • 天翼云市场商学院
天翼云合作计划
  • 云汇计划
天翼云东升计划
  • 适配中心
  • 东升计划
  • 适配互认证

开发者

开发者相关功能入口汇聚
技术社区
  • 专栏文章
  • 互动问答
  • 技术视频
资源与工具
  • OpenAPI中心
开放能力
  • EasyCoding敏捷开发平台
培训与认证
  • 天翼云学堂
  • 天翼云认证
魔乐社区
  • 魔乐社区

支持与服务

为您提供全方位支持与服务,全流程技术保障,助您轻松上云,安全无忧
文档与工具
  • 文档中心
  • 新手上云
  • 自助服务
  • OpenAPI中心
定价
  • 价格计算器
  • 定价策略
基础服务
  • 售前咨询
  • 在线支持
  • 在线支持
  • 工单服务
  • 建议与反馈
  • 用户体验官
  • 服务保障
  • 客户公告
  • 会员中心
增值服务
  • 红心服务
  • 客户支持计划
  • 专家技术服务
  • 备案管家

了解天翼云

天翼云秉承央企使命,致力于成为数字经济主力军,投身科技强国伟大事业,为用户提供安全、普惠云服务
品牌介绍
  • 关于天翼云
  • 智算云
  • 天翼云4.0
  • 新闻资讯
  • 天翼云APP
基础设施
  • 全球基础设施
  • 产品能力
  • 信任中心
最佳实践
  • 精选案例
  • 超级探访
  • 云杂志
  • 分析师和白皮书
  • 天翼云·创新直播间
市场活动
  • 2025智能云生态大会
  • 2024智算云生态大会
  • 2023云生态大会
  • 2022云生态大会
  • 天翼云中国行
天翼云
  • 活动
  • 智算服务
  • 产品
  • 解决方案
  • 应用商城
  • 合作伙伴
  • 开发者
  • 支持与服务
  • 了解天翼云
    • 关系数据库SQL Server版
    • 企业主机安全
    • 云防火墙
    • CDN加速
    • 物理机
    • GPU云主机
    • 天翼云电脑(政企版)
    • 天翼云电脑(公众版)
    • 云主机备份
    • 弹性云主机
      搜索发现
      关系数据库SQL Server版企业主机安全云防火墙CDN加速物理机GPU云主机天翼云电脑(政企版)天翼云电脑(公众版)云主机备份弹性云主机
    • 文档
    • 控制中心
    • 备案
    • 管理中心

    【JavaWeb】-- thymeleaf视图模板技术

    首页 知识中心 软件开发 文章详情页

    【JavaWeb】-- thymeleaf视图模板技术

    2024-07-16 10:03:45 阅读次数:35

    java,前端,开发语言

    什么是thymeleaf?

    在html页面上加载java内存数据,这个过程称为渲染,thymeleaf是用来帮助我们做视图渲染的一个技术,当通过 Web 应用程序访问时,Thymeleaf 会动态地替换掉静态内容,使页面动态显示。

    thymeleaf特点

    • 动静结合:Thymeleaf 既可以直接使用浏览器打开,查看页面的静态效果,也可以通过 Web 应用程序进行访问,查看动态页面效果。
    • 开箱即用:Thymeleaf 提供了 Spring 标准方言以及一个与 SpringMVC 完美集成的可选模块,可以快速的实现表单绑定、属性编辑器、国际化等功能。
    • 多方言支持:它提供了 Thymeleaf 标准和 Spring 标准两种方言,可以直接套用模板实现 JSTL、 OGNL 表达式;必要时,开发人员也可以扩展和创建自定义的方言。
    • 与 SpringBoot 完美整合:SpringBoot 为 Thymeleaf 提供了的默认配置,并且还为 Thymeleaf 设置了视图解析器,因此 Thymeleaf 可以与 Spring Boot 完美整合。

    th属性

    Thymeleaf 还提供了大量的 th 属性,这些属性可以直接在 HTML 标签中使用,其中常用 th 属性及其示例如下表。

    属性 描述 示例
    th:id 替换 HTML 的 id 属性
     
    • <input id="html-id" th:id="thymeleaf-id" />
    th:text 文本替换,转义特殊字符
     
    • <h1 th:text="hello,bianchengbang" >hello</h1>
    th:utext 文本替换,不转义特殊字符
     
    • <div th:utext="'<h1>欢迎来到编程帮!</h1>'" >欢迎你</div>
    th:object 在父标签选择对象,子标签使用 *{…} 选择表达式选取值。
    没有选择对象,那子标签使用选择表达式和 ${…} 变量表达式是一样的效果。
    同时即使选择了对象,子标签仍然可以使用变量表达式。
     
    • <div th:object="${session.user}" >
    • <p th:text="*{fisrtName}">firstname</p>
    • </div>
    th:value 替换 value 属性
     
    • <input th:value = "${}" />
    th:with 局部变量赋值运算
     
    • <div th:with="isEvens = ${prodStat.count}%2 == 0" th:text="${isEvens}"></div>
    th:style 设置样式
     
    • <div th:>编程帮 </div>
    th:onclick 点击事件
     
    • <td th:onclick = "'getInfo()'"></td>
    th:each 遍历,支持 Iterable、Map、数组等。
     
     
    • <table>
    • <tr th:each="m:${session.map}">
    • <td th:text="${m.getKey()}"></td>
    • <td th:text="${m.getValue()}"></td>
    • </tr>
    • </table>
    th:if 根据条件判断是否需要展示此标签
     
    • <a th:if ="${userId == collect.userId}">
    th:unless 和 th:if 判断相反,满足条件时不显示
     
    • <div th:unless="${m.getKey()=='name'}" ></div>
    th:switch 与 Java 的 switch case语句类似
    通常与 th:case 配合使用,根据不同的条件展示不同的内容
     
    • <div th:switch="${name}">
    • <span th:case="a">编程帮</span>
    • <span th:case="b"></span>
    • </div>
    th:fragment 模板布局,类似 JSP 的 tag,用来定义一段被引用或包含的模板片段
     
    • <footer th:fragment="footer">插入的内容</footer>
    th:insert 布局标签;
    将使用 th:fragment 属性指定的模板片段(包含标签)插入到当前标签中。
     
    • <div th:insert="commons/bar::footer"></div>
    th:replace 布局标签;
    使用 th:fragment 属性指定的模板片段(包含标签)替换当前整个标签。
     
    • <div th:replace="commons/bar::footer"></div>
    th:selected select 选择框选中
     
    • <select>
    • <option>---</option>
    • <option th:selected="${name=='a'}">
    • 编程帮
    • </option>
    • <option th:selected="${name=='b'}">
    • </option>
    • </select>
    th:src 替换 HTML 中的 src 属性 
     
    • <img th:src="@{/asserts/img/bootstrap-solid.svg}" src="asserts/img/bootstrap-solid.svg" />
    th:inline 内联属性;
    该属性有 text、none、javascript 三种取值,
    在 <script> 标签中使用时,js 代码中可以获取到后台传递页面的对象。
     
    • <script type="text/javascript" th:inline="javascript">
    • var name = /*[[${name}]]*/ 'bianchengbang';
    • alert(name)
    • </script>
    th:action 替换表单提交地址
    
    
    • <form th:action="@{/user/login}" th:method="post"></form>

    使用步骤

    1、添加thymeleaf的jar包

    【JavaWeb】-- thymeleaf视图模板技术

     2、新建Servlet类ViewBaseServlet

    package com.myssm.myspringmvc;
    import org.thymeleaf.TemplateEngine;
    import org.thymeleaf.context.WebContext;
    import org.thymeleaf.templatemode.TemplateMode;
    import org.thymeleaf.templateresolver.ServletContextTemplateResolver;
    
    import javax.servlet.ServletContext;
    import javax.servlet.ServletException;
    import javax.servlet.http.HttpServlet;
    import javax.servlet.http.HttpServletRequest;
    import javax.servlet.http.HttpServletResponse;
    import java.io.IOException;
    public class ViewBaseServlet extends HttpServlet {
    
        private TemplateEngine templateEngine;
    
        @Override
        public void init() throws ServletException {
    
            // 1.获取ServletContext对象
            ServletContext servletContext = this.getServletContext();
    
            // 2.创建Thymeleaf解析器对象
            ServletContextTemplateResolver templateResolver = new ServletContextTemplateResolver(servletContext);
    
            // 3.给解析器对象设置参数
            // ①HTML是默认模式,明确设置是为了代码更容易理解
            templateResolver.setTemplateMode(TemplateMode.HTML);
    
            // ②设置前缀
            String viewPrefix = servletContext.getInitParameter("view-prefix");
    
            templateResolver.setPrefix(viewPrefix);
    
            // ③设置后缀
            String viewSuffix = servletContext.getInitParameter("view-suffix");
    
            templateResolver.setSuffix(viewSuffix);
    
            // ④设置缓存过期时间(毫秒)
            templateResolver.setCacheTTLMs(60000L);
    
            // ⑤设置是否缓存
            templateResolver.setCacheable(true);
    
            // ⑥设置服务器端编码方式
            templateResolver.setCharacterEncoding("utf-8");
    
            // 4.创建模板引擎对象
            templateEngine = new TemplateEngine();
    
            // 5.给模板引擎对象设置模板解析器
            templateEngine.setTemplateResolver(templateResolver);
    
        }
    
        protected void processTemplate(String templateName, HttpServletRequest req, HttpServletResponse resp) throws IOException {
            // 1.设置响应体内容类型和字符集
            resp.setContentType("text/html;charset=UTF-8");
    
            // 2.创建WebContext对象
            WebContext webContext = new WebContext(req, resp, getServletContext());
    
            // 3.处理模板数据
            templateEngine.process(templateName, webContext, resp.getWriter());
        }
    }

    3、在web.xml文件中添加配置

    配置前缀 view-prefix

    配置后缀 view-suffix

        <!-- 配置上下文参数 -->
        <context-param>
            <param-name>view-prefix</param-name>
            <param-value>/</param-value>
        </context-param>
        <context-param>
            <param-name>view-suffix</param-name>
            <param-value>.html</param-value>
        </context-param>

    4、使Serlvet继承ViewBaseServlet

    public class IndexServlet extends ViewBaseServlet{.....}

    5、根据逻辑视图名称得到物理视图名称

    处理模板:processTemplate("xxx",request,response);

    此处视图名称是index;

    thymeleaf会将逻辑视图名称对应到物理视图名称上;

    逻辑视图名称:index;

    物理视图名称:view-prefix + 逻辑视图名称 + view-suffix(前面的xml配置文件中定义前后缀为/和.html)

    所以真实视图名称:/index.html

    例:

    package com.fruit.servlets;
    import com.fruit.dao.FruitDAO;
    import com.fruit.dao.impl.FruitDAOImpl;
    import com.fruit.pojo.Fruit;
    import com.myssm.myspringmvc.ViewBaseServlet;
    import javax.servlet.ServletException;
    import javax.servlet.annotation.WebServlet;
    import javax.servlet.http.HttpServletRequest;
    import javax.servlet.http.HttpServletResponse;
    import javax.servlet.http.HttpSession;
    import java.io.IOException;
    import java.util.List;
    @WebServlet("/index")
    public class IndexServlet extends ViewBaseServlet {
        @Override
        protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
            FruitDAO fruitDAO = new FruitDAOImpl();
            List<Fruit> fruitList = fruitDAO.getFruitList();
            //保存到session作用域
            HttpSession session = request.getSession();
            session.setAttribute("fruitList",fruitList);
            //处理模板,第一个参数为视图名称,会对应物理视图名称
            super.processTemplate("index",request,response);
        }
    }
    

    6、编辑html文件

    示例:

    <html xmlns:th="http://">
    	<head>
    		<meta charset="utf-8">
    		<link rel="stylesheet" href="css/index.css">
            <script language="JavaScript" src="js/index.js"></script>
    	</head>
    	<body>
    		<div id="div_container">
    			<div id="div_fruit_list">
    				<p >欢迎使用水果库存后台管理系统</p>
    				<div >
    					<a th:href="@{/add.html}" >添加新库存记录</a>
    				</div>
    				<table id="tbl_fruit">
    					<tr>
    						<th >名称1</th>
    						<th >单价</th>
    						<th >库存</th>
    						<th>操作</th>
    					</tr>
    					<tr th:if="${#lists.isEmpty(session.fruitList)}">
    						<td colspan="4">对不起,库存为空!</td>
    					</tr>
    					<tr th:unless="${#lists.isEmpty(session.fruitList)}" th:each="fruit : ${session.fruitList}">
    						<!-- <td><a th:text="${fruit.fname}" th:href="@{'/edit.do?fid='+${fruit.fid}}">苹果</a></td> -->
    						<td><a th:text="${fruit.fname}" th:href="@{/edit.do(fid=${fruit.fid})}">苹果</a></td>
    						<td th:text="${fruit.price}">5</td>
    						<td th:text="${fruit.fcount}">20</td>
    						<!-- <td><img src="imgs/del.jpg"  th:onclick="'delFruit('+${fruit.fid}+')'"/></td> -->
                            <td><img src="imgs/del.jpg"  th:onclick="|delFruit(${fruit.fid})|"/></td>
    					</tr>
    				</table>
    			</div>
    		</div>
    	</body>
    </html>
    版权声明:本文内容来自第三方投稿或授权转载,原文地址:https://blog.csdn.net/Tir_zhang/article/details/126167662,作者:四月天行健,版权归原作者所有。本网站转在其作品的目的在于传递更多信息,不拥有版权,亦不承担相应法律责任。如因作品内容、版权等问题需要同本网站联系,请发邮件至ctyunbbs@chinatelecom.cn沟通。

    上一篇:小试牛刀 docker三个mysql走起

    下一篇:java给pdf打水印

    相关文章

    2025-04-22 09:40:08

    【ETL工具】kettle 程序报错 Javascript error: TypeError: Cannot call method “trim“ of null

    【ETL工具】kettle 程序报错 Javascript error: TypeError: Cannot call method “trim“ of null

    2025-04-22 09:40:08
    java , javascript , org
    2025-04-22 09:28:31

    springboot实现图片或者其他文件回显功能

    springboot实现图片或者其他文件回显功能

    2025-04-22 09:28:31
    前端 , 接口 , 文件 , 路径
    2025-04-15 09:20:33

    初学Java,IO之文件过滤器(四十)

    初学Java,IO之文件过滤器(四十)

    2025-04-15 09:20:33
    File , java , 文件夹 , 方法
    2025-04-15 09:20:33

    初学Java,List和ListIterator(二十八)

    List代表的是一个有序的集合,每一个元素都有一个对应索引。List是Collection的子接口,所以Collection的所有方法都可以调用,另外也有它自身的方法。

    2025-04-15 09:20:33
    Arrays , java , List , Struts2
    2025-04-15 09:20:22

    初学Java,IO之使用转换流,读取键盘输入(四十三)

    初学Java,IO之使用转换流,读取键盘输入(四十三)

    2025-04-15 09:20:22
    buffer , import , java , string
    2025-04-15 09:20:07

    初学Java,IO之File用法(三十九)

    初学Java,IO之File用法(三十九)

    2025-04-15 09:20:07
    class , java
    2025-04-15 09:19:55

    初学Java,集合类的排序,查找,替换操作(三十五)

    初学Java,集合类的排序,查找,替换操作(三十五)

    2025-04-15 09:19:55
    java , list , 排序 , 替换 , 查找
    2025-04-14 09:26:51

    线性表练习之Example038-编写一个函数将链表 h2 链接到链表 h1 之后,要求链接后的链表仍然保持循环链表形式

    线性表练习之Example038-编写一个函数将链表 h2 链接到链表 h1 之后,要求链接后的链表仍然保持循环链表形式

    2025-04-14 09:26:51
    java , 数据结构
    2025-04-14 08:48:01

    使用Java消费API的一个错误消息PKIX path building failed以及解决方案

    使用Java消费API的一个错误消息PKIX path building failed以及解决方案

    2025-04-14 08:48:01
    java , Java , ssl
    2025-04-14 08:48:01

    如何处理Maven build时的error message Unable to locate the Javac Compiler in tools.jar

    如何处理Maven build时的error message Unable to locate the Javac Compiler in tools.jar

    2025-04-14 08:48:01
    jar , jar包 , java , Java
    查看更多
    推荐标签

    作者介绍

    天翼云小翼
    天翼云用户

    文章

    32777

    阅读量

    4845775

    查看更多

    最新文章

    【ETL工具】kettle 程序报错 Javascript error: TypeError: Cannot call method “trim“ of null

    2025-04-22 09:40:08

    springboot实现图片或者其他文件回显功能

    2025-04-22 09:28:31

    初学Java,IO之文件过滤器(四十)

    2025-04-15 09:20:33

    初学Java,List和ListIterator(二十八)

    2025-04-15 09:20:33

    初学Java,IO之使用转换流,读取键盘输入(四十三)

    2025-04-15 09:20:22

    初学Java,IO之File用法(三十九)

    2025-04-15 09:20:07

    查看更多

    热门文章

    JAVA__接口的作用

    2023-04-18 14:14:13

    Java学习之算术运算符两只老虎

    2023-04-19 09:23:13

    排序算法Java版-归并排序算法

    2023-04-24 11:25:19

    JAVA多线程学习笔记

    2023-05-11 06:05:48

    try...catch...finally java

    2023-03-29 09:40:26

    Java:apache.poi读写Excel文件

    2023-02-22 06:40:54

    查看更多

    热门标签

    java Java python 编程开发 开发语言 代码 算法 线程 html Python 数组 C++ javascript c++ 元素
    查看更多

    相关产品

    弹性云主机

    随时自助获取、弹性伸缩的云服务器资源

    天翼云电脑(公众版)

    便捷、安全、高效的云电脑服务

    对象存储

    高品质、低成本的云上存储服务

    云硬盘

    为云上计算资源提供持久性块存储

    查看更多

    随机文章

    寻找最近的回文数。 给定一个表示整数的字符串 n ,返回与它最近的回文整数(不包括自身)。如果不止一个,返回较小的那个。 “最近的”定义为两个整数差的绝对值最小。 示例 1: 输

    Java中的类继承与多态

    Centos开机启动Java程序

    Spring系列之@Value与static共存

    有接口的CGLIB动态代理实现

    Java 时间处理(格式解释、格式化时间、获取当前时间、获取年份、月份等、时间戳转换成时间)

    • 7*24小时售后
    • 无忧退款
    • 免费备案
    • 专家服务
    售前咨询热线
    400-810-9889转1
    关注天翼云
    • 权益商城
    • 天翼云APP
    • 天翼云微信公众号
    服务与支持
    • 备案中心
    • 售前咨询
    • 智能客服
    • 自助服务
    • 工单管理
    • 客户公告
    • 涉诈举报
    账户管理
    • 管理中心
    • 订单管理
    • 余额管理
    • 发票管理
    • 充值汇款
    • 续费管理
    快速入口
    • 权益商城
    • 文档中心
    • 最新活动
    • 免费试用
    • 信任中心
    • 天翼云学堂
    云网生态
    • 甄选商城
    • 渠道合作
    • 云市场合作
    了解天翼云
    • 关于天翼云
    • 天翼云APP
    • 服务案例
    • 新闻资讯
    • 联系我们
    热门产品
    • 云电脑
    • 弹性云主机
    • 云电脑政企版
    • 天翼云手机
    • 云数据库
    • 对象存储
    • 云硬盘
    • Web应用防火墙
    • 服务器安全卫士
    • CDN加速
    热门推荐
    • 云服务备份
    • 边缘安全加速平台
    • 全站加速
    • 安全加速
    • 云服务器
    • 云主机
    • 智能边缘云
    • 应用编排服务
    • 微服务引擎
    • 共享流量包
    更多推荐
    • web应用防火墙
    • 密钥管理
    • 等保咨询
    • 安全专区
    • 应用运维管理
    • 云日志服务
    • 文档数据库服务
    • 云搜索服务
    • 数据湖探索
    • 数据仓库服务
    友情链接
    • 中国电信集团
    • 189邮箱
    • 天翼企业云盘
    • 天翼云盘
    ©2025 天翼云科技有限公司版权所有 增值电信业务经营许可证A2.B1.B2-20090001
    公司地址:北京市东城区青龙胡同甲1号、3号2幢2层205-32室
    • 用户协议
    • 隐私政策
    • 个人信息保护
    • 法律声明
    备案 京公网安备11010802043424号 京ICP备 2021034386号