我需要根据所选的t:dataTable行禁用该按钮。 这是我正在调用行选择事件的javascript方法 (如果所选行中的项目有工具提示,则应禁用该按钮...这很难看,但这是最简单的事情):
function processUpdateButton() {
if (!$(".selectedRow").length
|| $(".selectedRow").children().find(".tooltip").length){
$(".Update").button({disabled:true});
} else {
$(".Update").button({disabled:false});
};
}
这是JSF commandLink:
<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生成的按钮,那将是很好的。
答案 0 :(得分:1)
所以我找到了解决方案。我将onclick属性复制到禁用按钮上的另一个属性,反之亦然:
var onclick;
if (!$(".selectedRow").length
|| $(".selectedRow").children().find(".tooltip").length){
$(".Update").button({disabled:true});
onclick=$(".Update").attr('onclick');
$(".Update").attr('onclick2',onclick);
$(".Update").removeAttr('onclick');
} else {
$(".Update").button({disabled:false});
onclick=$(".Update").attr('onclick2');
$(".Update").attr('onclick',onclick);
$(".Update").removeAttr('onclick2');
};
答案 1 :(得分:0)
正如您所看到的,生成的html代码不是按钮而是超链接。因此,您需要从链接标记中删除链接。可以尝试以下:
$(".Update").removeAttr('href');