我需要根据 t:dataTable 的选定行禁用按钮。这是我在行选择事件上调用的 javascript 方法(如果所选行中的项目有工具提示,则应禁用该按钮......这很丑陋,但这是最容易做的事情):
function processUpdateButton() {
if (!$(".selectedRow").length
|| $(".selectedRow").children().find(".tooltip").length){
$(".Update").button({disabled:true});
} else {
$(".Update").button({disabled:false});
};
}
这是 JSF 命令链接:
<h:commandLink id="update" styleClass="Update iconButton"
action="#{myBB.update}"
value="#{gui['button.update']}"
tabindex="301"/>
为按钮设置禁用属性有效。该按钮是灰色的,如果我将鼠标悬停在它上面,光标不会像其他链接那样改变。问题是,我仍然可以单击它并调用支持 bean 中的方法。有什么办法可以防止这种情况发生吗?这是呈现的禁用按钮:
<a id="mainForm:update"
class="iconButton ... ui-button-disabled ui-state-disabled"
onclick="return myfaces.oam.submitForm('mainForm','mainForm:update');"
href="#" role="button" aria-disabled="true" disabled="disabled">
<span class="ui-button-text">Update</span>
</a>
我可能应该删除 onClick 属性,但我不知道如何才能再次启用它。
当然,我可以在单击更新按钮后检查服务器上的情况,但这是最后的手段。如果我可以完全禁用 JSF 仅从 javascript 生成的按钮而不调用服务器,那就太好了。