我有一个关于从用于填充选择表单的列表中检索对象的问题。
控制器:
@RequestMapping(value="listStaffMembers", method=RequestMethod.GET)
public String listStaffMembers(Model model){
model.addAttribute("staffList", this.personManager.getAllStaff());
Person person = new Person();
model.addAttribute("staffMember", person);
model.addAttribute("staffListSize", this.personManager.getAllStaff().size());
for (Person persons : this.personManager.getAllStaff())
System.out.println("Query Name:" + persons.getName() + " Id:"+persons.getId());
return "staffList";
}
未接收 Person 对象的控制器:
@RequestMapping(value="staffMemberCRUD",
method=RequestMethod.POST)
//ModelAndView
public String staffMemberCRUD(@ModelAttribute("staffMember")Person person, Model model){
if(person!=null){
model.addAttribute("staffMember", person);
String name = person.getName();
int id = person.getId();
System.out.println("id: "+ id);
System.out.println("name: "+ name);
return "staffForm";
}else{
System.out.println("Person not saved, no entry, throwing null pointer exception");
throw new NullPointerException();
}
}
人物类:
@Entity(name="STAFF")
@NamedQuery(name="staffDetails.byId", query="from STAFF")// where userId = ?, then use position 0, then value
public class Person {
@Id
@GeneratedValue(strategy=GenerationType.AUTO)
private int id;
@Column(name="NAME")
private String name;
public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public Person(int personId, String name){
setId(personId);
setName(name);
}
public Person(String name){
setName(name);
}
public Person(int Id){
setId(Id);
}
public Person(){
}
}
下面的表单如何检索对象,id 出现在 person 的 name 变量中,尽管没有 id 值。
<FORM ACTION="staffMemberCRUD" METHOD=POST ><!-- onSubmit="return dropdown(this.gourl) -->
<table>
<tr>
<td>
<select name="staffMember">
<option value="">Choose</option>
<c:forEach items="${staffList}" var="prod">
<option value ="${prod.id}"><c:out value="${prod.id}"></c:out><c:out value="${prod.name}"></c:out></option>
</c:forEach>
</select>
</td>
</tr>
</table>
<INPUT TYPE=SUBMIT VALUE="Go">
</FORM>
Person 类还用于使用休眠填充数据库,这会混淆问题吗?
在测试 listStaffMembers 下拉列表时,它只是当前不起作用的帖子。我已经为此查看了 Spring 文档,它让我走到了这一步,非常感谢任何帮助,因为到目前为止这已经花费了我 3 天的时间,但没有任何积极的结果。非常感谢,院长
Latest Update:
更新了表单:选择,请注意选择路径现在发布“id”,以及正确的表单:表单标签,POST 后下一个视图中的人员对象现在填充了一个 id 字段,这比之前提到的要少再次从数据库中找到它们:
<form:form action="staffMemberCRUD" commandName="staffMember"><!-- onSubmit="return dropdown(this.gourl) -->
<table>
<tr>
<td>
<form:select path="id">
<form:option value="-1">Select your Staff Member</form:option>
<form:options items="${staffList}" itemLabel="name" itemValue="id" />
</form:select>
</td>
</tr>
</table>
<INPUT TYPE=SUBMIT VALUE="Go">
</form:form>
我知道 PropertyEditor 仍然是前进的方向,当这种情况发生时我会再次更新。