confirmDialog 没有取 selectOneMenu 的新值 [英] confirmDialog is not taken the new value of the selectOneMenu

查看:84
本文介绍了confirmDialog 没有取 selectOneMenu 的新值的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我需要更改数据库中的状态,但是当我更改状态时,confirmDialog 没有采用新值,而是使用旧值

I need to change the status in database but when I change the status the confirmDialog is not taking the new value, it gets the old one

<p:selectOneMenu converter="omnifaces.SelectItemsConverter" disabled="#{myBB.currentStatus != StatusEnum.TEMP}"
    id="statusSOM" onchange="PF('confirm').show();" value="#{myBB.currentStatus}" widgetVar="statusWV">
    <f:selectItems itemDisabled="#{status == StatusEnum.ALL}" itemLabel="#{msgs[status.name]}"
        itemValue="#{status}" value="#{myBB.statusList}" var="status" />
</p:selectOneMenu>

<p:confirmDialog widgetVar="confirm" message="Save?" header="Confirm" severity="alert">
    <p:commandButton action="#{myBB.saveStatus}" oncomplete="PF('confirm').hide();"
        update="form1 form2" value="Yes" />
    <p:commandButton value="No" type="button"
        onclick="PF('statusWV').selectValue(PF('statusWV').preShowValue.val());PF('confirm').hide();" />
</p:confirmDialog>

我能做什么?

推荐答案

您需要在更新值时更新您的 p:confirmDialog 组件.如果您在 p:selectOneMenu 上使用方便的 p:ajax,那就很简单了.

You need to update your p:confirmDialog component when the value is updated. That's straightfoward if you use the handy p:ajax on your p:selectOneMenu.

<p:selectOneMenu converter="omnifaces.SelectItemsConverter" disabled="#{myBB.currentStatus != StatusEnum.TEMP}" id="statusSOM" value="#{myBB.currentStatus}" widgetVar="statusWV">
     <f:selectItems itemDisabled="#{status == StatusEnum.ALL}" itemLabel="#{msgs[status.name]}" itemValue="#{status}" value="#{myBB.statusList}" var="status" />
     <p:ajax event="change" update="confirmdialog" oncomplete="PF('confirm').show()" />
</p:selectOneMenu>

<p:confirmDialog id="confirmdialog" widgetVar="confirm" message="Save?" header="Confirm" severity="alert">
    ...
</p:confirmDialog>

这篇关于confirmDialog 没有取 selectOneMenu 的新值的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆