5

我有一个关于从用于填充选择表单的列表中检索对象的问题。

控制器:

@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 仍然是前进的方向,当这种情况发生时我会再次更新。

4

0 回答 0