0

我创建了这个带有问题对话框的 JSF 按钮示例:

<!-- hidden button -->
<h:commandButton id="deleterow" value="HiddenDelete"  action="#{AccountProfileTabGeneralController.saveData}" style="display:none" update="growl">
    <f:ajax render="@form" execute="@form"></f:ajax>
</h:commandButton>

<!-- edit button -->
<h:button style="position:absolute; bottom:12px; right:12%;" rendered="#{AccountProfileTabGeneralController.editable}" styleClass="lbimage" value=" Save Account " onclick="editdialog(this, 'Do you want to save the changes?'); return false;" />

我使用这个 JS 来显示对话框:

function editdialog(button, a){      
    $("<div />", {
        text: a
    }).dialog({        
        width: 600,
        buttons: {
            "Ok": function() { 
                $("#form\\:deleterow").click();
                $(this).dialog("close");
                button.value = "Processing...";
                button.disabled = true;                  
            }, 
            "Cancel": function(event) { 
                $(this).dialog("close");
                event.preventDefault();
                button.value = "Save Account";
                button.disabled = false;
            } 
        }
    });         
}

但是由于某种原因,然后我单击“确定”按钮,该按钮被禁用并且它不起作用,也许表单的 ID 不正确。我用这个<h:form id="general">

我该如何解决这个问题?以及如何在具有不同 ID 的表单中使用代码?

4

1 回答 1

2

如果您将表单的 id 设置为“general”,则 jQuery 选择器可能应该是

$("#general\\:deleterow")

但正如您所指出的,您可能有不同的形式,因此选择器非常具体。

我想你会想要这样的东西:

$(button).closest("form").find("[id$=deleterow]").click();

form这样做是找到启动该功能的按钮的第一个父元素editDialog,然后在该表单内找到id以“deleterow”结尾的任何元素。这应该可以工作,因为该id元素的将类似于“form_id:deleterow”。

于 2012-11-01T20:27:54.183 回答