【WEEK11】 【DAY4】员工管理系统第五部分【中文版】

2024.5.9 Thursday

接上文【WEEK11】 【DAY3】员工管理系统第四部分【中文版】

目录

10.6.增加员工

10.6.1.修改list.html

第53行,把<h2>Section title</h2>修改成添加员工的按钮

html 复制代码
<h2><a class="btn btn-sm btn-success" th:href="@{/emp}">添加员工</a></h2>

10.6.2.修改EmployeeController.java

添加新方法

java 复制代码
package com.P14.controller;

import com.P14.dao.DepartmentDao;
import com.P14.dao.EmployeeDao;
import com.P14.pojo.Department;
import com.P14.pojo.Employee;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Controller;
import org.springframework.ui.Model;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.RequestMapping;

import java.util.Collection;

@Controller
public class EmployeeController {
    //查询所有员工
    @Autowired
    EmployeeDao employeeDao;
    @Autowired  //自动注入
    DepartmentDao departmentDao;

    @RequestMapping("/emps")    //只要dashboard.html请求了th:href="@{emps}(line89)则跳转到运行@RequestMapping("/emps")
    public String list(Model model){    //然后会查询所有员工,此时再修改:如何显示到前端页面
        Collection<Employee> employees = employeeDao.getAll();
        model.addAttribute("emps",employees);
        return "emp/list";
    }

    @GetMapping("/emp") //get请求获取跳转
    public String toAddpage(Model model){
        //查出所有部门的信息
        Collection<Department> departments = departmentDao.getDepartment();
        model.addAttribute("departments",departments);
        return "emp/add";
    }

    @PostMapping("/emp")
    public String addEmp(Employee employee){
        //添加的操作 forward
        System.out.println("save=>"+employee);
        employeeDao.save(employee); //调用底层业务方法保存员工信息
        return "redirect:/emps";    //在"添加员工"页面点击"添加"后重定向到"员工管理"页面
    }
}

10.6.3.新建add.html

list.html相比,只需要修改<main>内包含的内容

html 复制代码
<body>
   <div th:replace="~{common/commons::topbar}"></div>
   <!--改为插入commons.html中的topbar部分-->
   <div class="container-fluid">
      <div class="row">
         <div th:replace="~{common/commons::sidebar(active='list.html')}"></div>
         <!--改为插入commons.html中的sidebar部分-->
         <main role="main" class="col-md-9 ml-sm-auto col-lg-10 pt-3 px-4">
            <form th:action="@{/emp}" method="post">
               <div class="form-group">
                  <label>LastName</label>
                  <input type="text" name="lastName" class="form-control" placeholder="海绵宝宝">
               </div>
               <div class="form-group">
                  <label>Email</label>
                  <input type="email" name="email" class="form-control" placeholder="987654321@qq.com">
               </div>
               <div class="form-group">
                  <label>Gender</label><br>
                  <div class="form-check form-check-inline">
                     <input class="form-check-input" type="radio" name="gender" value="1">
                     <label class="form-check-label">女</label>
                  </div>
               </div>
               <div class="form-check form-check-inline">
                  <input class="form-check-input" type="radio" name="gender" value="0">
                  <label class="form-check-label">男</label>
               </div>
               <div class="form-group">
                  <label>department</label>
                  <select class="form-control" name="department.id">
                     <!--我们在controller接收的是一个Employee,所以我们需要提交的是其中的一个属性(department.id)-->
                     <option th:each="dept:${departments}" th:text="${dept.getDepartmentName()}" th:value="${dept.getId()}"></option>
                  </select>
               </div>
               <div class="form-group">
                  <label>Birth</label>
                  <input type="text" name="birth" class="form-control" placeholder="2020/07/25 18:00:00">
               </div>
               <button type="submit" class="btn btn-primary">添加</button>
            </form>
         </main>
      </div>
   </div>

   ...

</body>

10.6.4.重启并运行

登录后选择"员工管理"->"添加员工"->填写相关信息->点击"添加"

默认页面:

输入信息后点击"添加":

注意添加日期的格式是yyyy/MM/dd,而不是yyyy-MM-dd

Console栏:

相关推荐
幽络源小助理5 分钟前
小六壬排盘工具源码 自适应双端 纯原生HTML+JS
前端·javascript·html
Slow菜鸟6 分钟前
Codex CLI 教程(五)| AI 驱动项目从零到一:面向 Java 全栈工程师打造个人 ECC(V2版)
java·开发语言·人工智能
月落归舟15 分钟前
java基础之拷贝、单例
java·单例·拷贝
鬼蛟19 分钟前
什么是 Git
java
空中海37 分钟前
第二篇:注册中心篇 — Nacos 与 Eureka 服务注册发现
spring boot·云原生·eureka
直奔標竿40 分钟前
SpringAI + RAG + MCP + Agent 零基础全栈实战(完结篇)| 27课完整汇总,Java开发者AI转型必看
java·开发语言·人工智能·spring boot·后端·spring
云烟成雨TD41 分钟前
Spring AI 1.x 系列【31】向量数据库:进阶使用指南
java·人工智能·spring
Championship.23.241 小时前
Open Source Pipeline Skill深度解析:自动化开源贡献全流程
前端·javascript·html
Bigger1 小时前
🧠 前端岗位的"结构性调整":现象背后的冷思考
前端·程序员·ai编程
逍遥德1 小时前
SpringBoot数据库连接池HikariCP,Druid,Tomcat JDBC,DBCP2,c3p0配置使用
数据库·spring boot·tomcat