Spring 全家桶之 Spring Boot 2.6.4(六)- Web Develop(Part C)(上)

简介: Spring 全家桶之 Spring Boot 2.6.4(六)- Web Develop(Part C)

四、Employee List 开发

跳转至Employee List 页面

在templates目录下增加employee文件夹,将list.html页面放入该文件夹下。在controller包中新建EmployeeController,增加list方法来获取Employee列表,然后返回list.html页面

@Controller
public class EmployeeController {
    @Autowired
    private EmployeeMapper employeeMapper;
    @GetMapping("/list")
    public String list(Model model){
        Collection<Employee> list = employeeMapper.getAll();
        model.addAttribute("list", list);
        return "employee/list";
    }
}
复制代码

将dashboard.html页面的Employee List超链接改为/list

<li class="nav-item">
   <a class="nav-link" href="#" th:href="@{/list}">
      <svg xmlns="http://www.w3.org/2000/svg"  width="24" height="24" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" class="feather feather-users">
         <path d="M17 21v-2a4 4 0 0 0-4-4H5a4 4 0 0 0-4 4v2"></path>
         <circle cx="9" cy="7" r="4"></circle>
         <path d="M23 21v-2a4 4 0 0 0-3-3.87"></path>
         <path d="M16 3.13a4 4 0 0 1 0 7.75"></path>
      </svg>
      Employee List
   </a>
</li>
复制代码

重新启动应用,登录后点击Employee List

image.png

页面跳转到list.html页面,并且无任何错误信息

抽取公共页面

由于list.html和dashboard.html的顶部和侧边栏都是相同的,因此可以将顶部和侧边栏抽取为公共页面

Thymeleaf官网中 8 Template Layout 提到了如何抽取公共页面

image.png

首先要在index.html的顶部导航栏设置一个fragment

image.png

然后在list.html页面通过th:insert标签来引入前面设置的fragment

image.png

重新启动应用

image.png

页面顶部导航栏能够正确显示

页面引入方式包括th:insert,共有三种引入方式

  • th:insert,将公共片段插入到这个声明引入的元素中
  • th:replace,将声明引入的元素替换为公共片段
  • th:include,将被引入的片段内容包含到这个标签中

因此需要将insert替换为replace

image.png

抽取侧边栏时,给侧边栏设置一个id为selector

image.png

引入时通过id选择器引入公共片段

image.png

重新启动应用,查看页面顶部导航栏和侧边栏

image.png

修改过后,侧边栏能够正常显示

抽取公共片段到单独页面

上面定义的公共片段还是在具体的页面中,可以将公共页面,顶部和侧边栏单独抽取到一个html页面中,降低耦合

新建一个bar.html,将顶部导航栏和侧边栏拷贝到该页面中

image.png

在dashboard.html页面和list.html页面引入公共片段

image.png

侧边目录高亮

当进入到list.html页面时,左侧的目录并没有高亮显示,想要解决在具体页面高亮对应的目录需要在公共片段进行变量值判断,每个变量引用时都设置一个该片段独有的值。关于变量可以查看thymeleaf官方文档 8.2 Parameterizable fragment signatures

image.png

首先在公共片段目录增加变量判断,如果activeUri为list,就高亮,否则不高亮显示

image.png

list页面设置的activeUri变量的值为list

image.png

dashboard页面设置的activeUri的值为dashboard

image.png

重新启动应用

image.png

每个页面对应的目录都可以高亮显示

显示员工数据列表

使用for循环取出list列表中的全部属性,员工的gender使用0和1表示,这里可以进行判断,用男和女代替0和1

image.png

重启应用,查看员工列表

image.png

五、Add Employee

进入Add Employee 页面

Add Hero 增加超链接,跳转至添加页面

image.png

拷贝list.html页面并重命名为add.html,从Bootstrap [Components] (getbootstrap.com/docs/4.0/co…) 拷贝第二个表单到add.html页面

在EmployeeController增加视图映射,点击按钮跳转到add.html页面

@GetMapping("/employee")
public String employee(Model model){
    return "employee/add";
}



相关文章
|
3月前
|
Java API 数据库
构建RESTful API已经成为现代Web开发的标准做法之一。Spring Boot框架因其简洁的配置、快速的启动特性及丰富的功能集而备受开发者青睐。
【10月更文挑战第11天】本文介绍如何使用Spring Boot构建在线图书管理系统的RESTful API。通过创建Spring Boot项目,定义`Book`实体类、`BookRepository`接口和`BookService`服务类,最后实现`BookController`控制器来处理HTTP请求,展示了从基础环境搭建到API测试的完整过程。
65 4
|
2天前
|
存储 安全 Java
Spring Boot 3 集成Spring AOP实现系统日志记录
本文介绍了如何在Spring Boot 3中集成Spring AOP实现系统日志记录功能。通过定义`SysLog`注解和配置相应的AOP切面,可以在方法执行前后自动记录日志信息,包括操作的开始时间、结束时间、请求参数、返回结果、异常信息等,并将这些信息保存到数据库中。此外,还使用了`ThreadLocal`变量来存储每个线程独立的日志数据,确保线程安全。文中还展示了项目实战中的部分代码片段,以及基于Spring Boot 3 + Vue 3构建的快速开发框架的简介与内置功能列表。此框架结合了当前主流技术栈,提供了用户管理、权限控制、接口文档自动生成等多项实用特性。
26 8
|
14天前
|
缓存 前端开发 Java
【Spring】——SpringBoot项目创建
SpringBoot项目创建,SpringBootApplication启动类,target文件,web服务器,tomcat,访问服务器
|
1月前
|
Java 开发者 微服务
Spring Boot 入门:简化 Java Web 开发的强大工具
Spring Boot 是一个开源的 Java 基础框架,用于创建独立、生产级别的基于Spring框架的应用程序。它旨在简化Spring应用的初始搭建以及开发过程。
67 6
Spring Boot 入门:简化 Java Web 开发的强大工具
|
2月前
|
监控 Java 数据库连接
详解Spring Batch:在Spring Boot中实现高效批处理
详解Spring Batch:在Spring Boot中实现高效批处理
261 12
|
2月前
|
安全 Java 测试技术
详解Spring Profiles:在Spring Boot中实现环境配置管理
详解Spring Profiles:在Spring Boot中实现环境配置管理
104 10
|
1月前
|
负载均衡 Java 开发者
深入探索Spring Cloud与Spring Boot:构建微服务架构的实践经验
深入探索Spring Cloud与Spring Boot:构建微服务架构的实践经验
148 5
|
2月前
|
存储 运维 安全
Spring运维之boot项目多环境(yaml 多文件 proerties)及分组管理与开发控制
通过以上措施,可以保证Spring Boot项目的配置管理在专业水准上,并且易于维护和管理,符合搜索引擎收录标准。
55 2
|
2月前
|
XML Java 网络架构
使用 Spring Boot 公开 SOAP Web 服务端点:详细指南
使用 Spring Boot 公开 SOAP Web 服务端点:详细指南
75 0
|
3月前
|
Java 测试技术 开发者
springboot学习四:Spring Boot profile多环境配置、devtools热部署
这篇文章主要介绍了如何在Spring Boot中进行多环境配置以及如何整合DevTools实现热部署,以提高开发效率。
120 2
下一篇
开通oss服务