0

私はこの editor.xhtml を持っています。ここには、エディターと一連のボタンと、そのボタンの確認ダイアログがあります。これらはすべて、Web アプリケーションのダイアログで使用できます。

editor.xhtml:

<ui:composition
        xmlns:c="http://java.sun.com/jsp/jstl/core"
        xmlns:f="http://java.sun.com/jsf/core"
        xmlns:h="http://java.sun.com/jsf/html"
        xmlns:ui="http://java.sun.com/jsf/facelets"
        xmlns:p="http://primefaces.org/ui">

        <p:confirmDialog widgetVar="saveDialog" appendTo="@(body)" showEffect="fade" hideEffect="fade"
                          message="Do you want to save the content?" icon="ui-icon-disk" severity="info" closable="true" >
            <p:commandButton value="Yes" styleClass="ui-confirmdialog-yes" icon="ui-icon-check" action="#{customEditorBean.save}" oncomplete="PF('saveDialog').hide()"  />
            <p:commandButton value="No" type="button" styleClass="ui-confirmdialog-no" icon="ui-icon-close" onclick="PF('saveDialog').hide()" />
        </p:confirmDialog>

        <h:form>
            <span id="editorWidgetVarId">
                <p:editor widgetVar="editorWidget" onchange="rc()" value="#{customEditorBean.sisalto}" width="600" maxlength="8000" />
            </span>
            <p:remoteCommand delay="700" name="rc" actionListener="#{customEditorBean.noticeChange}" process="@this" update="saveButton"/>

            <p:commandButton id="saveButton"  onclick="PF('saveDialog').show()" value="Save" rendered="#{customEditorBean.canSave}"
            disabled="#{!customEditorBean.saveEnabled}" type="button">
            </p:commandButton>
        </h:form>

</ui:composition>

CustomEditorBean には、呼び出される save メソッドがあります。このメソッドは、confirmDialog をこの editor.xhtml に追加する前に機能していたため、正しく機能します。ここで、エディターに何かを記述しても、エディターの値はバッキング Bean で更新されません。したがって、保存すると、保存ボタンをクリックする前にエディターに書き込んだ値ではなく、エディターの古い値が保存されます。これを修正する方法はありますか?

4

1 に答える 1