14

私は2ページ目にありますp:dataTable。左は主に選択に使用します

<p:dataTable id="leftTable" var="item" value="#{bean.items}"
             selection="#{bean.item}" selectionMode="single">
  <p:ajax event="rowSelect" update=":rightTable" listener="#{bean.select}"/>  
  <p:column>
    <h:outputText value="#{item.value}" />  
  </p:column>
</p:dataTable>

これはかなり単純で、正常に機能します。rightTableはより複雑なもので、これは単純化された例です

<p:dataTable id="rightTable" var="row" value="#{bean.rows}">
  <p:columns var="col" value="#{bean.cols}">  
    <h:outputText value="#{bean.map[row.id][col.id]}"/>
  </p:columns>
</p:dataTable>

まあ、これもうまくいきます。ここで、 leftTablecomposite componentを置き換えるためにを実装しました。このコンポーネントにも属性があり、一般的には動作します。fromと同じメソッドが呼び出され、正しい項目が設定されます。selectionselectp:dataTable

しかし、これは本当に厄介なことです。カスタムコンポーネントを使用する場合、最初のセル(列0、行0)の値は常にnullです。値はaから取得され、メソッドが呼び出された後にMap<Long,Map<Long,String>>特定の値が設定されていることを確認しました。row.id,col.id

私はこの問題について完全に無知な切り株であり、この質問に答えるのは本当に難しいことを期待しており、誰かがこの問題をより詳細にデバッグするのを手伝ってくれるかどうか本当に感謝しています。

Upate 1:リクエストにより:をチェックしました#{row.id},#{col.id}

95,626 | 95,528
96,527 | 96,528
97,527 | 97,528

最初のセルのcol.idが間違っています。あるべきです527が、実際626のものです(前のリクエストの値です)。なぜこれが起こるのですか?どうすれば正しい値を取得できますか?

アップデート2:これは私のコンポーネントです:

<composite:interface componentType="my.MenuDmClick">
  <composite:attribute name="actionListener" required="true"
        method-signature="void listener(javax.faces.event.AjaxBehaviorEvent)"/>
  <composite:attribute name="selection"/>
  <composite:attribute name="update/>
  <composite:attribute name="dm"/>
</composite:interface>
<composite:implementation>
  <ui:repeat var="item" value="#{cc.attrs.dm.wrappedData}">
  <li>
    <p:commandLink actionListener="#{cc.actionListener(item)}"
                   update="#{cc.attrs.update}">
      <h:outputText value="#{item.name}"/>
    </p:commandLink>
  </li>
  </ui:repeat>
</composite:implementation>

そして、これはバッキングBeanです。

@FacesComponent(value="my.MenuDmClick")
public class MenuDmClick extends UINamingContainer
{
  public void actionListener(Object ejb)
  {
    FacesContext context = FacesContext.getCurrentInstance();
    ValueExpression mSelection = this.getValueExpression("selection");

    if(mSelection!=null){mSelection.setValue(context.getELContext(), ejb);}
    else{throw new PropertyNotFoundException("'selection' must be a ValueExpression!");}

    MethodExpression ajaxEventListener =
         (MethodExpression) getAttributes().get("actionListener");
    ajaxEventListener.invoke(context.getELContext(), new Object[] {});
  }
}
4

1 に答える 1

0

のような通常のものを試した後

  • ui:repeatおよびc:forEach
  • 即時=true/ false

私は出くわしましたprocess=@this...そしてそれは魅力のように機能します!

<c:forEach var="item" items="#{cc.attrs.dm.wrappedData}">
  <li>
    <p:commandLink process="@this"
        actionListener="#{cc.actionListener(item)}" update="#{cc.attrs.update}">
      <h:outputText value="#{item.round.name}"/>
    </p:commandLink>
  </li>
</c:forEach>
于 2013-06-07T06:24:52.990 に答える