2

selectOneMenu を機能させようとしています。フィルター入力で選択を表示するように管理しましたが、そこに何かを書き込もうとすると、すべてが消えてしまいます。

ビューからのコードは次のとおりです。

<p:selectOneMenu style="width:160px" label="Supervisor" filter="true" filterMatchMode="startsWith" converter="userConverter">
    <f:selectItem itemLabel="Choose..." itemValue="" />
    <f:selectItems value="#{userBean.supervisors}" var="user" itemLabel="#{user.surname} #{user.name}" itemValue="#{user}"/>
</p:selectOneMenu>

userBean.supervisors によって渡される値は、次によって提供されます。

public List<User> getSupervisors() {
    if (supervisors == null) {
        supervisors = userDao.getUsersByRole(Enums.Roles.SUPERVISOR.getValue());
    }
    return supervisors;
}

そしてコンバーターは簡単です:

@FacesConverter(forClass = User.class, value="userConverter")
public class UserConverter implements Converter {

@Override
public String getAsString(FacesContext context, UIComponent component, Object value) {
    if(value == "") return null;
    // Convert ProjectDetail to its unique String representation.
    User user = (User) value;
    String idAsString = String.valueOf(user.getUserId());
    return idAsString;
}

@Override
public Object getAsObject(FacesContext context, UIComponent component, String value) {
    // Convert unique String representation of ProjectDetail back to ProjectDetail object.
    Long id = Long.valueOf(value);
    UserDAO userDao = new UserDAO();
    User user = userDao.getUser(id);
    return user;
}
}

p:selectOneMenu を p:selectCheckboxMenu フィルタリングに変更すると、すべてがうまく機能します。

4

1 に答える 1

0

この css でチェックして結果を表示します。

.ui-selectonemenu-items-wrapper{
    height: auto !important;
}
于 2014-07-01T08:36:51.637 に答える