java – Spring MVC将嵌套的Custom类型的列表绑定到多个JSP表单
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了java – Spring MVC将嵌套的Custom类型的列表绑定到多个JSP表单,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含8055字,纯文字阅读大概需要12分钟。
内容图文
![java – Spring MVC将嵌套的Custom类型的列表绑定到多个JSP表单](/upload/InfoBanner/zyjiaocheng/824/b24f0dc8b680440d8ca89ef34ece76b3.jpg)
案子:
我有一个组织对象.它有一个Department Objects列表,每个Department都有一个Employee Objects列表.
在JSP中,我有一个复选框列表,它将一个复选框绑定到一个雇员对象(深层次的2个层次结构.即Organization-> Department-> Employee).
<input type="checkbox" name="adminDepartmentList[${status.index}].employeeList" value="${employee.firstName}"> <c:out value="${employee.firstName}" /><br>
如你看到的:
adminDepartmentList[0].employeeList --> John
adminDepartmentList[2].employeeList --> Rose
绑定很好.提交表单后,在控制器中,我可以遍历admin departmentList并查找创建的所有部门,并查找由于复选框选择而创建的员工.
问题:(部门是使用空名称和非null employeeList创建的.我找不到employeeList所属部门的名称:(那么如何传递一些部门名称,以便将名称注入部门(如正在创建)就像“.employeeList”被注入部门一样.
细节:
为了给你我的工作细节:
Organization类有两个Departments列表.
Department类有一个Employees列表.
员工有姓名和小时工作.
public class Organization{
private long id;
private String name;
private List<Department> adminDepartmentList; //n admin departments
private List<Department> employeeDepartmentList //m employee departments
// default constructor and all getters and setters
}
public class Department{
private long id;
private String name;
private List<Employee> employeeList; //k employees
//default constructor and all getters and setters
}
public class Employee{
private long id;
private String firstName;
private String lastName;
private int hoursToWork; // to be filled from Spring MVC form
//default contructor and all getters and setters
}
部门列表来自API.该部门的所有员工都来自另一个API.
我正在编写一个客户端,通过首先选择他们感兴趣的部门来创建“自定义组织”,然后对于所选的每个部门,用户从与该部门相关的所有员工中选择一部分员工.
所以我有3个JSP表单:
组织表单(organization.jsp):组织名称的输入字段和所有部门的复选框列表.用户可以为正在创建的新组织选择一组部门.
<form:form name='fs' action="department.htm" method='POST' commandName="organization">
Organization Name:
<input type="text" name="name" >
<!-- ============================================================== -->
Departments:<br> Select admin-departments you want.
<div class="checkbox-list">
<%-- Size :<c:out value="${organization.adminDepartmentList.size}"/> --%>
<c:forEach var="i" varStatus="status" items="${organization.adminDepartmentList}">
<input type="checkbox" name="adminDepartmentList" value="${i.name}"> <c:out value="${i.name}" /><br>
</c:forEach>
</div>
<!-- ============================================================== -->
Departments:<br> Select employee-departments you want.
<div class="checkbox-list">
<c:forEach var="i" varStatus="status" items="${organization.employeeDepartmentList}">
<input type="checkbox" name="employeeDepartmentList" value="${i.name}"> <c:out value="${i.name}" /><br>
</c:forEach>
</div>
<button type="submit" class="btn btn-lg btn-primary btn-block">Next Step</button>
</form:form>
部门表单(department.jsp):对于所选的每个部门,这将显示要为部门选择的员工的复选框列表.
<form:form name='f' action="employee.htm" method='POST' commandName="organization">
Organization Name: <c:out value="${organization.name}" /><br>
Select Employees you want for your new Departments.
Admin Departments:<br>
<c:forEach var="department" varStatus="status" items="${organization.adminDepartmentList}">
______Dept: <c:out value="${department.name}" /><br>
<div class="checkbox-list">
<c:forEach var="employee" varStatus="status" items="${department.employeeList}">
<input type="checkbox" name="adminDepartmentList[${status.index}].employeeList" value="${employee.firstName}"> <c:out value="${employee.firstName}" /><br>
</c:forEach>
</div>
</c:forEach>
Employee Departments:<br>
<c:forEach var="department" varStatus="status" items="${organization.employeeDepartmentList}">
______Dept: <c:out value="${department.name}" /><br>
<div class="checkbox-list">
<c:forEach var="employee" varStatus="status" items="${department.employeeList}">
<input type="checkbox" name="employeeDepartmentList[${status.index}].employeeList" value="${employee.firstName}"> <c:out value="${employee.firstName}" /><br>
</c:forEach>
</div>
</c:forEach>
<button type="submit" class="btn btn-lg btn-primary btn-block">Next Step</button>
</form:form>
员工表单(employee.jsp):对于在“部门表单”中选择的每个员工,这将显示员工姓名和输入将分配给该员工的小时数的字段.
员工控制器(获得null部门名称的那个)
@RequestMapping(value = "/employee", method = RequestMethod.POST)
public String product_post(@ModelAttribute("organization") Organization organization, HttpServletRequest request,
HttpServletResponse response, BindingResult result, ModelMap model) {
System.out.println("=========== POST Employee CONTROLLER===============");
//STEP 1. show me which employees are selected for each admin department.
List<Department> adminDepartments = organization.getAdminDepartmentList();
for(Department dept: adminDepartments){
System.out.println("Admin Dept name::: " + dept.getName()); //<-----------Name Comes as null :(
List<Employee> employeeList = dept.getEmployeeList();
for(Employee emp: employeeList){
System.out.println("Employee::"+ emp.getFirstName());
}
}
//STEP 2. show me which employees are selected for each employee department.
List<Department> employeeDepartments = organization.getEmployeeDepartmentList();
for(Department dept: employeeDepartments){
System.out.println("Employee Dept name::: " + dept.getName()); //<----------Name Comes as null :(
List<Employee> employeeList = dept.getEmployeeList();
for(Employee emp: employeeList){
System.out.println("Employee::"+ emp.getFirstName());
}
}
model.addAttribute("organization", organization);
return "employee";
}
已知:
我理解为什么没有注入department.name,但我不确定如何解决它.如何将外部循环中的部门名称注入到下面c:foreach中员工列表上运行的内部循环?或者如何以某种方式将其绑定到每个员工.我怀疑它在这里:
Admin Departments:<br>
<c:forEach var="department" varStatus="status" items="${organization.adminDepartmentList}">
______Dept: <c:out value="${department.name}" /><br>
<div class="checkbox-list">
<c:forEach var="employee" varStatus="status" items="${department.employeeList}">
<input type="checkbox" name="adminDepartmentList[${status.index}].employeeList" value="${employee.firstName}"> <c:out value="${employee.firstName}" /><br>
</c:forEach>
</div>
</c:forEach>
我尝试了隐藏的输入来帮助创建命名部门,但它没有帮助.
积分:
非常感谢您的合作:)
为简单起见,假设员工的FirstName是唯一的.而department.name也是独一无二的.
谢谢.
解决方法:
新闻:哦,哇,圣洁的莫莉牛,我解决了它.
失踪部分:
隐藏的输入,告诉您要创建的部门以及要注入的名称.
<form:hidden path="adminDepartmentList[${statusDepartment.index}].name" value="${department.name}" />
将部门名称注入spring创建的每个部门.
整体解决方案:
department.jsp
<form:form name='f' action="employee.htm" method='POST' commandName="organization">
Organization Name: <c:out value="${organization.name}" /><br>
Select Employees you want for your new Departments.
Admin Departments:<br>
<c:forEach var="department" varStatus="statusDepartment" items="${organization.adminDepartmentList}">
______Dept: <c:out value="${department.name}" /><br>
<div class="checkbox-list">
<form:hidden path="adminDepartmentList[${statusDepartment.index}].name" value="${department.name}" />
<c:forEach var="employee" varStatus="statusEmployee" items="${department.employeeList}">
<form:checkbox path="adminDepartmentList[${statusDepartment.index}].employeeList" value="${employee.firstName}"/> <c:out value="${employee.firstName}" /><br>
</c:forEach>
</div>
</c:forEach>
Employee Departments:<br>
<c:forEach var="department" varStatus="statusDepartment" items="${organization.employeeDepartmentList}">
______Dept: <c:out value="${department.name}" /><br>
<div class="checkbox-list">
<form:hidden path="employeeDepartmentList[${statusDepartment.index}].name" value="${department.name}" />
<c:forEach var="employee" varStatus="statusEmployee" items="${department.employeeList}">
<form:checkbox path="employeeDepartmentList[${statusDepartment.index}].employeeList" value="${employee.firstName}"/> <c:out value="${employee.firstName}" /><br>
</c:forEach>
</div>
</c:forEach>
<button type="submit" class="btn btn-lg btn-primary btn-block">Next Step</button>
</form:form>
内容总结
以上是互联网集市为您收集整理的java – Spring MVC将嵌套的Custom类型的列表绑定到多个JSP表单全部内容,希望文章能够帮你解决java – Spring MVC将嵌套的Custom类型的列表绑定到多个JSP表单所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。