在selectOneMenu的五个选项中,我选择了第二个选项并保留了实体。 在编辑时,持久化实体selectOneMenu始终将最后一个选项作为其值。
例如,
<h:selectOneMenu value="#{userHome.user.leader}">
<f:selectItems value="#{userHome.availableLeaders}" var="leader" itemLabel="# {leader.name}" itemValue="#{leader}"/>
</h:selectOneMenu>
其中availableLeaders是填充@PostConstruct方法的用户列表。
我希望selectOneMenu在编辑时有第二个选项(选择)。
@FacesConverter(forClass = User.class, value = "userConverter")
public class UserConverter implements Converter {
public UserConverter() {
}
@Override
public Object getAsObject(FacesContext context, UIComponent component,
String value) {
EntityManagerFactory emf = Persistence.createEntityManagerFactory("DefaultPersistenceUnit");
EntityManager em = emf.createEntityManager();
Query q = em.createQuery("select query");
return q.resultList().get(0);
}
@Override
public String getAsString(FacesContext context, UIComponent component,
Object value) {
return ((User) value).getName();
}}
在User.java中
public boolean equals(Object other) {
if (this.getClass().isInstance(other)) {
return true;
} else {
return false;
}
}
public int hashCode() {
HashCodeBuilder builder = new HashCodeBuilder();
builder.append(getId());
builder.append(getName());
return builder.toHashCode();
}
答案 0 :(得分:4)
看这里:
public boolean equals(Object other) {
if (this.getClass().isInstance(other)) {
return true;
} else {
return false;
}
}
您的equals()
方法肯定会被破坏。这会为每个其他true
对象返回User
,即使它在内部拥有完全不同的用户ID /名称。因此,所选项目与每个可用的选择项目值匹配。这就是为什么你每次都看到最后一个项目被预先选定的。
假设id
属性对于每个用户都是唯一的,那么equals()
方法最简单的应该是这样的:
public boolean equals(Object other) {
if (!(other instanceof User)) {
return false;
}
if (other == this) {
return true;
}
if (id != null) {
return id.equals(((User) other).id);
}
return false;
}
也可归纳如下
public boolean equals(Object other) {
return (other instanceof User) && (id != null) ? id.equals(((User) other).id) : (other == this);
}
提示:像Eclipse这样有点像IDE可以自动生成equals()
(和hashCode()
)方法。