Primefaces SelectOneMenu,自定义内容不显示列



我遇到了在SelectOneMenu中显示自定义内容的问题。我现在使用的是Primefaces 3.5,我测试了展示中的示例,它工作正常,所以不幸的是问题是PEBCAC。
这是我的转换器代码:

@Override
public Object getAsObject(FacesContext ctx, UIComponent component, String id)
{
    groups = getGroups();//gets the groups here
    pType toReturn = new pType();
    if(groups.size()>0){
      toReturn = groups.get(0);
      return toReturn;
     }
   return "";       
}
@Override
public String getAsString(FacesContext fc, UIComponent uic, Object o)
{
    if (o == null || o.equals(""))
    {
        return "---";
    } else
    {           
        try{
            pType val = (pType)o;
            return String.valueOf(val.getRecordID());
        }catch(Exception ex){               
            ex.printStackTrace();
            return "---";
        }
    }
}

这是我现在正在使用的xhtml:

<p:selectOneMenu value="#{controller.selectedVal}"
        rendered="#{controller.showMenu}" effect="fade"
        converter="converter" panelStyle="width:150px" var="p"
        style="width:160px" filter="true" filterMatchMode="contains">
        <f:selectItem itemLabel="Select One" itemValue="" />
        <f:selectItems var="pType"
            itemLabel="#{controller.getNumber(pType)}"
            itemValue="#{pType}" value="#{controller.savedValues}">
                    <p:column>#{p.var1} - #{p.var2}
                    </p:column>
                </f:selectItems>
</p:selectOneMenu>

控制器是SessionScoped的managedbean。变量savedValues是一个对象列表,它确实填充了正确的数据,并且在调用时具有数据。现在使用上面的代码,列表只是打开,里面没有数据。如果我将变量切换为"pType"而不是"p",则下拉菜单将有一个从controller.getNumber(pType)获得的值列表,尽管没有自定义数据被加载到菜单中。但是我所看到的所有例子都表明,所使用的变量来自selectOneMenu,这也是我有点困惑的地方,因为它似乎应该总是来自selectems的值字段。

首先,我会尝试删除所有不必要的属性,如过滤器或渲染,并转向更简单,直到您有一个工作版本。这将比您期望的更频繁地隔离错误。

你有你的转换器注释为FacesConverter与正确的名称和类吗?getGroups()方法究竟做了什么,它是否在转换器中包含正确的值 ?为什么getAsObject总是返回第一个pType?

itemLabel实际上应该是什么,难道您不希望结果是显示pType的id或名称吗?

  • selectOneMenu value:所选项的值
  • selectonemenu_var:可在p:column
  • 中访问的项
  • selectItems itemLabel:在下拉菜单中显示的文本
  • selectItems itemValue:发送给bean设置器的实际值

相关内容

  • 没有找到相关文章

最新更新