SpringBoot中使用Thymeleaf进行页面的跳转和值传递

SpringBoot中引入Thymleaf技术

1、pom.xml中导入依赖

		<!-- thymeleaf会对html中的标签进行严格校验,如果html标签缺少结束标签的话,thymeleaf会报错,我们可以通过下面方式去除thymeleaf的校验 -->
        <dependency>
            <groupId>net.sourceforge.nekohtml</groupId>
            <artifactId>nekohtml</artifactId>
            <version>1.9.22</version>
        </dependency>
		<dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-thymeleaf</artifactId>
        </dependency>
        

2、application.yml

server:
  port: 9999
spring:
  thymeleaf:
  	# 默认的页面返回路径public static final String DEFAULT_PREFIX = "classpath:/templates/";
  	# public static final String DEFAULT_SUFFIX = ".html";
  	# 具体路径根据实际情况而定
  	prefix: classpath:/templates/
    suffix: .html
    cache: false
    mode: LEGACYHTML5
  application:
    name: springboot-thymeleaf
#thymeleaf end

具体 thymeleaf 能设置的属性 可以查看 类ThymeleafProperties

3、测试接口

package com.test.controller;

import org.springframework.stereotype.Controller;
import org.springframework.ui.Model;
import org.springframework.util.StringUtils;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.servlet.ModelAndView;

import java.util.ArrayList;
import java.util.List;

@Controller
@RequestMapping("login")
public class LoginController {

	//使用Model
    @PostMapping("login1")
    public String login(Model model,String username , String password){
        List<String> list = new ArrayList<>();
        list.add("赵云");
        list.add("关羽");
        list.add("张飞");
        list.add("黄忠");
        list.add("马超");
        model.addAttribute("msg",list);
        return "index";
    }
	
	//使用ModelAndView
	 @PostMapping("login2")
    @PostMapping("login2")
    public ModelAndView login(String username , String password){
        ModelAndView mav = new ModelAndView("index");
        if(StringUtils.isEmpty(username)){
            mav.addObject("msg", "用户名不能为空");
            return mav;
        }
        if(StringUtils.isEmpty(password)){
            mav.addObject("msg","密码不能为空");
            return mav;
        }
        if("admin".equals(username) && "admin".equals(password)){
            List<String> list = new ArrayList<>();
            list.add("赵子龙");
            list.add("关云长");
            list.add("张翼德");
            list.add("黄汉升");
            list.add("马孟起");
            mav.addObject("msg",list);
            return mav;
        }else{
            mav.addObject("msg","用户名或者密码错误");
            return mav;
        }
    }
}

4、login页面

需要引入thymeleaf的命名空间
如果引入的js,css文件不起作用,需要使用以下方式

<link th:href="@{/css/bootstrap.min.css}" rel="stylesheet" type="text/css" />
<script type="text/javascript" th:src="@{/js/jquery.js}"></script>
<!DOCTYPE html>
<html lang="en" xmlns:th="https://www.thymeleaf.org">
<head>
    <meta charset="UTF-8">
    <title>登录</title>
</head>
<body>
<h1>登录页面</h1>
<form action="/login/login" method="post">
    用户名:<input name="username"type="text"/>
    <br>&nbsp;&nbsp;&nbsp; 码:<input name="password"type="text"/>
    <br>
    <button type="submit">登录</button>
</form>
</body>
</html>

5、跳转的index页面

<!DOCTYPE html>
<html lang="en" xmlns:th="https://www.thymeleaf.org">
<head>
    <meta charset="UTF-8">
    <title>测试</title>

    <link rel="stylesheet" href="/css/bootstrap/style.css"/>
</head>
<body>
<h1>测试页面</h1>
<div th:each="item : ${msg}">
    <h1 th:text="${{item}}"></h1>
</div>
</body>
</html>

6、前端部分目录结构

在这里插入图片描述

登录页面
在这里插入图片描述

跳转页面
在这里插入图片描述

  • 1
    点赞
  • 15
    收藏
    觉得还不错? 一键收藏
  • 4
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值