【问题标题】:commandLink disabled via javascript can still be clicked仍然可以单击通过 javascript 禁用的 commandLink
【发布时间】:2013-08-09 13:24:17
【问题描述】:

我需要根据 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 生成的按钮而不调用服务器,那就太好了。

【问题讨论】:

  • 您的“最后手段”是您唯一的选择。组件的状态在服务器端维护。因此,您的 disabled 属性的 javascript 更新仍需要以某种方式传达给服务器,以便运行时尊重它
  • 确实如此。但我只想阻止用户触发事件。请参阅下面的解决方案。我知道这不是很安全(因为当有人手动破解元素时服务器仍会处理该事件),但在我的情况下这不是问题。

标签: java javascript jquery jsf tomahawk


【解决方案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');
};

【讨论】:

    【解决方案2】:

    如您所见,生成的 html 代码不是按钮,而是超链接。所以你需要从链接标签中删除链接。可以尝试如下:

    $(".Update").removeAttr('href');
    

    【讨论】:

    • 谢谢。我会试试看。但这仍然是一个谜,浏览器中的光标并没有像其他超链接那样发生变化。
    • 是一样的。 href 消失了,但我仍然可以单击它。我想我需要禁用 onClick 事件,但我不知道该怎么做才能重新启用它。
    • 可以试试,.removeAttr('onclick');
    • 这行得通,但我会放弃 JSF 生成的 onclick 事件。这是一个问题,因为我希望能够重新启用它,如果我随后执行$(".Update").attr('onclick', 'return myfaces.oam.submitForm('mainForm','mainForm:update');') 之类的操作,我担心代码会非常脆弱,并且将来肯定会中断。我只想隐藏生成的 onclick 事件,但我不确定如何
    猜你喜欢
    • 1970-01-01
    • 2012-09-10
    • 1970-01-01
    • 1970-01-01
    • 2020-10-22
    • 2013-08-14
    • 2021-11-02
    • 1970-01-01
    • 2021-12-12
    相关资源
    最近更新 更多