「SpringBoot实战」视图技术-Thymeleaf

「SpringBoot实战」视图技术-Thymeleaf,第1张

在一个Web应用中,通常会采用MVC设计模式实现对应的模型、视图和控制器,其中,视图是用户看到并与之交互的界面。对最初的Web应用来说,视图是由HTML元素组成的静态界面;而后期的Web应用更倾向于使用动态模板技术,从而实现前后端分离和页面的动态数据展示。Spring Boot框架为简化项目的整体开发,提供了一些视图技术支持,并主要推荐整合模板引擎技术实现前端页面的动态化内容。本文对SpringBoot常用的Thymeleaf进行整合。

Thymeleaf是一种现代的基于服务器端的Java模板引擎技术,也是一个优秀的面向Java的XML、XHTML、HTML5页面模板,它具有丰富的标签语言、函数和表达式,在使用Spring Boot框架进行页面设计时,一般会选择 Thymeleaf模板。我们在这里学习Thymeleaf 常用的标签、表达式。

Thymeleaf标签

使用标签只需要加上一个命名空间就可以了。 即修改原html的第二行就可以了。

变量表达式${}主要用于获取上下文中的变量值,示例代码如下。

这是标题

- 使用了Thymeleaf模板的变量表达式${}用来动态获取p标签中的内容 - 如果当前程序没有启动或者当前上下文中不存在title变量,该片段会显示标签默认值“这是标题”; - 如果当前上下文中存在title 变量并且程序已经启动,当前p标签中的默认文本内容将会被tite变量的值所替换,从而达到模板引擎页面数据动态替换的效果。

Thymeleaf为变量所在域提供了一些内置对象

结合上述内置对象的说明,假设要在Thymeleaf模板擎页面中动态获取当前国家信息,可以使用#locale内置对象

选择交量表达式和变量表达式用法类似,一般用于从被选定对象而不是上下文中获取属性值,如果没有选定对象,则和变量表达式一样,示例代码如下。

消息表达式#{}主要用于Thymeleaf模板页面国际化内容的动态替换和展示。使用消息表这式#{}进行国际化设置时,还需要提供一些国际化配置文件。关于消息表达式的使用,下文写国际化时会详细说明。

链接表达式@{}一般用于页面跳转或者资源的引入,在Web开发中占据着非常重要的地位,并且使用也非常频繁。

片段表达式~{}是一种用来将标记片段移动到模板中的方法。其中,最常见的用法是使用th:insert或th:replace 属性插入片段

Spring Boot默认设置了静态资源的访问路径,默认将/所有访问映射到以下目录。

我们创建一个springboot项目用于本次实验。项目名为springboot_01_thyme。java8,springboot266

创建一个LoginController类用于数据替换效果测试。

我们写一个loginhtml进行测试。我们导入一个bootstrap的样式到static/login里面,并且自己定义一些css。

最后我们通过访问>

一个产品的发行就算再差,也都会有它的优点和缺点,就只是在于你看它对于那个方面,所以一个产品的发行你要客观的去认识它,都有必要大体看待。对于thymeleaf的测试结果很糟糕,但是spring去推荐使用它,肯定是有好处的。

首先主要是thymeleaf的实现机制相较于其他模板引擎更加的优雅。由于各种绑定与控制采用属性的方式,绑定的机制可以采用属性的方式,你就试想一下,你打游戏有属性加成是不是很好用的,你有属性加成就会有可以使得模板不破坏html原有的语法结构,那么就会有不一样的效果,这样就获得了其他模板引擎没有的一个重要特性:thymeleaf定义的模板是可以被正常渲染的。那么这样你改模板和测试就会非常方便,你是不是就会更好 *** 作,这是有利的。

其次就是Thymeleaf 的生产力比较好。它的生产能力非常强,它的标签比较简单,最大的优点,那么就是非常好的,所以要正确看待,它允许前端人员即时查看静态页面的效果,有的制造商时没有其它模板做不到的功能。所以你要学会考虑到横向添加服务很方便,那么你就意想不到,所以效率并不是什么大问题。

它的性能不是唯一指标,也就是让它一定能力,除此外还需要考虑开发效率它们的测试效率用户体验等等,比如你想减少内部的服务器资源消耗,完全可以把大部分渲染工作丢给用户浏览器,对他来的可能也就有一点点卡,那你就不好去考虑,所以你就会考虑其他的,毕竟要好的才会有人去推荐,不然谁会推荐。


欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/zz/10784680.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2023-05-11
下一篇2023-05-11

发表评论

登录后才能评论

评论列表(0条)

    保存