1

私はrich:Datatableを動的な列で持っています...ここまでは大丈夫です...データベースからすべてのデータを取得し、コードは正しい値を持つすべてのチェックボックスを表示します...しかし、それらを変更して「salvar」をクリックすると反対側の値をボタンで押しても以前と同じです...しかし、inputTextをrich:Datatableの外に置くと

<h:inputText value="#{matrix.teste}"/> 

そして、任意の値を入力し、「salvar」をクリックして、前に入力した値が正しく私の家に送られます...

    <ui:param name="matrix" value="#{inscricaoMatrix}" />
        <a4j:outputPanel id="matrixCredenciamento">
    <a4j:form>
            <rich:dataTable value="#{matrix.rows}" var="row" id="matrix" rendered="#{not empty query.inscricoes}">

            <rich:column label="Nome">
                <f:facet name="header">
                    <h:outputText value="Nome" />
                </f:facet>
                <h:outputText value="#{row.nome}" />
            </rich:column>
            <rich:column label="E-mail">
                <f:facet name="header">
                    <h:outputText value="E-mail" />
                </f:facet>
                <h:outputText value="#{row.email}" />
            </rich:column>
            <rich:column label="Credenciamento">
                <f:facet name="header">
                    <h:outputText value="Credenciamento" />
                </f:facet>
                <h:selectBooleanCheckbox value="#{row.credenciamento}" />
            </rich:column>


                <ui:param name="y" value="#{matrix.rows.indexOf(row)}" />

                <rich:columns value="#{matrix.columns}" var="col" index="x" style="text-align: center; width: 60px;">

                    <ui:param name="index" value="#{y * matrix.columns.size() + x}" />
                    <ui:param name="cell" value="#{matrix.cells[index]}" />

                    <f:facet name="header">
                        <h:outputText value="#{col.horario}" escape="true">
                            <f:convertDateTime  pattern="dd/MM/yyyy HH:mm"/>
                        </h:outputText>
                    </f:facet>
                    <h:selectBooleanCheckbox value="#{cell}" />

                </rich:columns>
            </rich:dataTable>

            <h:inputText value="#{matrix.teste}"/> 

            <h:commandButton id="salvar" value="Salvar" action="#{matrix.update()}" />          

        </a4j:form>
        </a4j:outputPanel>  
</ui:composition>

誰かが問題になる可能性があることを知っていますか?このページを追加するために(ui:includeを使用して)そのページを別のページで操作しています...

4

1 に答える 1

0

良い、

解決策を探していましたが、最善の方法が見つかりませんでした...回避策を使用して問題を解決しました...

<h:selectBooleanCheckbox value="#{cell}" name="presencasHorarios" onclick="setPresencas(#{index},this.checked)"/>

そして、次のような js 関数を作成しました。

<a4j:jsFunction name="setPresencas" action="#{matrix.addAlteracaoPresenca()}">
            <a4j:actionparam name="param1" assignTo="#{matrix.index}"  />
            <a4j:actionparam name="param2" assignTo="#{matrix.presenca}"  />        
</a4j:jsFunction>

反対側では、リストを作成しました...そのため、配列のインデックスとこのアイテムの新しい値を渡します...永続化または更新するために送信すると、そのリストを読んで、どのアイテムが変更されたかを確認し、それの新しい値...簡単にするために、インデックスと値を渡すHashMapを作成しました...したがって、ユーザーが値を1000回変更すると、値は最後の値になります...

于 2011-08-24T12:59:25.827 に答える