更新bean消息值,然后在<p:confirmdialog>中显示它

时间:2015-07-13 19:48:31

标签: jsf primefaces message confirm

有谁能告诉我如何更改<p: confirm>的讯息?当您单击按钮时,我希望messageCount ()方法返回值消息。

...

<p:outputLabel value="Test:" />                        
<p:inputText value="#{testController.fieldTest}" id="fieldTest"/>

...

<p:commandButton value="Ok" action="#{testController.cadTest()}">
    <p:confirm id="messageConfirm" header="Test" />
</p:commandButton>

...

<p:confirmDialog global="true" showEffect="fade" hideEffect="fade">
    <f:facet name="message">
        <p:outputPanel>
            <h:outputFormat id="message" value="#{testController.mensagemConfirm}" escape="false"/>
        </p:outputPanel>
    </f:facet>
    <p:commandButton value="Yes" type="button" styleClass="ui-confirmdialog-yes" icon="ui-icon-check" />
    <p:commandButton value="No" type="button" styleClass="ui-confirmdialog-no" icon="ui-icon-close" />
</p:confirmDialog>

...


//TestController

private String mensagemConfirm;
private Integer count = 0;


public Integer messageCount() {
    return count++;
}

public String getMensagemConfirm() {
    setMessageConfirm("Count: " + messageCount());
    return mensagemConfirm;
}

public void setMensagemConfirm(String mensagemConfirm) {
    this.mensagemConfirm = mensagemConfirm;
}

示例:

  • 首先点击&#34;确定&#34; (<p:commandButton>

    - &GT;确认对话消息:计数:1 (单击&#34;否&#34;)

  • Secound单击&#34;确定&#34; (<p:commandButton>

    - &GT;确认对话消息:计数:2 (点击&#34;否&#34;)

  • 三点击&#34;确定&#34; (<p:commandButton>

    - &GT;确认对话消息:计数:3 (点击&#34;否&#34;)

2 个答案:

答案 0 :(得分:0)

根据您的解释,您似乎只想在用户点击&#34;否&#34;

之后增加count

因此,您可以在commandButton中使用actionListener属性,该属性将使用ajax请求调用increment方法:

<p:commandButton value="No"  actionListener="#{testController.incrementCount()}" ajax="true" styleClass="ui-confirmdialog-no" icon="ui-icon-close"/>
  • 请注意,我删除了属性type=button,如果我没有,则不会调用该方法

显示当前值:

 <h:outputFormat id="message" value="Count: #{testController.count}" escape="false"/>

控制器:

Integer count = 0;
public void incrementCount() {
   count++;
}
public Integer getCount(){
   return count;
}

答案 1 :(得分:0)

这里的问题是,在您按下confirmDialog中的“是”之前,p:confirm将不会执行您的服务器端代码。因此,您必须先执行某些操作才能执行服务器端代码,并在完成ajax请求后显示确认对话框。

您可以通过显示带有oncomplete属性的确认对话框来执行此操作:

    <p:commandButton value="Ok" update="conf" action="#{testController.increaseCount()}" oncomplete="PF('confirmVar').show()"/>

    <p:confirmDialog id="conf" global="true" showEffect="fade" hideEffect="fade" widgetVar="confirmVar">

        <p:commandButton value="Yes" action="#{testController.cadTest()}" styleClass="ui-confirmdialog-yes" icon="ui-icon-check" oncomplete="PF('confirmVar').hide()"/>
        <p:commandButton value="No" styleClass="ui-confirmdialog-no" icon="ui-icon-close" oncomplete="PF('confirmVar').hide()"/>

        <f:facet name="message">
            <p:outputPanel>
                <h:outputFormat value="Count: #{testController.count}" escape="false"/>
            </p:outputPanel>
        </f:facet>
    </p:confirmDialog>

在纯粹的getter / setter中执行应用程序逻辑代码也是糟糕的设计。使用专门的方法。

testController bean:

private int count;

public int getCount() {
    return count;
}

public void setCount(int count) {
    this.count = count;
}

public void increaseCount() {
   count++;
}