SpringBoot集成Thymeleaf前端模板

boyanx8个月前技术教程34

Thymeleaf是一个模板引擎。它是一个强大的模板引擎,可以处理HTML、XML、JavaScript、CSS等多种类型的模板。Thymeleaf可以与Spring MVC框架集成,以便在Web应用程序中使用模板。本文介绍一下与SpringBoot集成过程和案例。

首先配置依赖

<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-thymeleaf</artifactId>
    <version>2.7.10</version>
</dependency>

配置模板信息

templates是模板文件存放位置,在resources资源路径下

.html 是模板文件后缀


@Configuration
public class ThymeleafConfig {
    Logger logger = LoggerFactory.getLogger(ThymeleafConfig.class);

    @Bean
    public SpringResourceTemplateResolver templateResolver() {
        SpringResourceTemplateResolver templateResolver = new SpringResourceTemplateResolver();
        templateResolver.setApplicationContext(applicationContext);
        //文件存储位置 
        templateResolver.setPrefix("classpath:/templates/");
        //模板文件后缀
        templateResolver.setSuffix(".html");
        templateResolver.setTemplateMode(TemplateMode.HTML);
        templateResolver.setCharacterEncoding("UTF-8");
        templateResolver.setCheckExistence(true);
        return templateResolver;
    }

    @Autowired
    private ApplicationContext applicationContext;
}

Controller写法

返回ModelAndView,跳转到指定页面

@RequestMapping("/userView")
public ModelAndView userView(Long userId) {
    logger.info("userView controller");
    ModelAndView modelAndView = new ModelAndView();
    modelAndView.addObject("userEntity", helloBiz.getUser(userId));
    modelAndView.setViewName("user");
    return modelAndView;
}

通过addObject 存储一个键值对 key是userEntity ,value是一个用户实体

设置viewName是 user ,对应的模板为user.html

界面写法

界面文件路径为
/resources/templates/user.html

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>
用户标识:<span class="author" th:text="${userEntity.userId}"></span>
用户名称:<span class="author" th:text="${userEntity.nickName}"></span>
</body>
</html>

模板语法参考官方文档,文档地址如下

官方文档:
https://www.thymeleaf.org/doc/tutorials/2.1/usingthymeleaf.html

看看效果


后面介绍如何集成LayUI,做个管理后台界面,喜欢请关注,不对的地方请指正

相关文章

SpringBoot+LayUI后台管理系统开发脚手架

源码获取方式:关注,转发之后私信回复【源码】即可免费获取到!项目简介本项目本着避免重复造轮子的原则,建立一套快速开发JavaWEB项目(springboot-mini),能满足大部分后台管理系统基础开...

初学Java需要重视的10个知识点(学java需要掌握什么)

Java的知识点其实非常多,并且有些知识点比较难以理解,有时候我们自以为理解了某些内容,其实可能只是停留在表面上,没有理解其底层实现原理。纸上得来终觉浅,绝知此事要躬行。学习Java基础的时候,应该尽...

基于LayUI的博客前后端模板(前端个人博客模板)

断更了好久,这次争取能连续把这个博客代码搞完;最近自学了一些前端内容,几月LayUI设计的博客管理前后台,先截图看看前后端样式吧博客系统基于springboot开发,mybatis,mysql数据库,...

酷瓜云课堂(内网版)v1.0.6 发布,局域网在线学习平台

更新内容增加刷新 opcache 功能增加清理测试数据脚本首页轮播 + 课程合并为首页缓存强化文章 | 提问 | 课程列表参数检查优化课程学习时长同步优化排序条件,改善分页重复问题优化文件上传优化学员...

Layui简单实现左侧菜单和Tab选项卡动态操作

<!DOCTYPE html> <html> <head> <meta charset="utf-8">...

【推荐】强&amp;牛!一款开源免费的功能强大的代码生成器系统!

今天,给大家推荐一个代码生成器系统项目,这个项目目前收获了 5.3K Star,个人觉得不错,值得拿出来和大家分享下。这是我目前见过最好的代码生成器系统项目。功能完整,代码结构清晰。 项目介绍本项目是...

发表评论    

◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。