我有一个input type="image"。这类似于Microsoft Excel中的单元格注释。如果有人在与此输入图像配对的文本框中输入数字,我将为输入图像设置一个事件处理程序。然后,当用户单击图像时,他们会看到一个小弹出窗口,向数据中添加一些注释。

我的问题是,当用户在文本框中输入0时,我需要禁用输入图像的事件处理程序。我试过以下方法,但都没用。

$('#myimage').click(function { return false; });

当前回答

jQuery≥1.7

随着jQuery 1.7的更新,事件API已经更新,.bind()/.unbind()仍然可以向后兼容,但首选的方法是使用on()/off()函数。下面是,

$('#myimage').click(function() { return false; }); // Adds another click event
$('#myimage').off('click');
$('#myimage').on('click.mynamespace', function() { /* Do stuff */ });
$('#myimage').off('click.mynamespace');

jQuery < 1.7

在你的示例代码中,你只是在图像中添加了另一个点击事件,而不是覆盖前一个:

$('#myimage').click(function() { return false; }); // Adds another click event

这两个单击事件都将被触发。

正如人们所说,你可以使用unbind删除所有点击事件:

$('#myimage').unbind('click');

如果你想添加一个事件,然后删除它(不删除任何其他可能已添加的事件),那么你可以使用事件命名空间:

$('#myimage').bind('click.mynamespace', function() { /* Do stuff */ });

然后删除你的事件:

$('#myimage').unbind('click.mynamespace');

其他回答

我必须使用道具和attr将事件设置为null。我不能只选一个。我也无法摆脱工作的束缚。我正在做TD元素。

.prop("onclick", null).attr("onclick", null)

也许解绑定方法对您有用

$("#myimage").unbind("click");

你可以添加onclick处理程序作为内联标记:

<input id="addreport" type="button" value="Add New Report" onclick="openAdd()" />

如果是这样,jquery .off()或.unbind()将不起作用。你需要在jquery中添加原始的事件处理程序:

$("#addreport").on("click", "", function (e) {
   openAdd();
});

然后jquery有一个事件处理程序的引用,可以删除它:

$("#addreport").off("click")

VoidKing在上面的评论中更间接地提到了这一点。

这也很好。简单易行。参见http://jsfiddle.net/uZc8w/570/

$('#myimage').removeAttr("click");

如果.on()方法之前与特定选择器一起使用,如下例所示:

$('body').on('click', '.dynamicTarget', function () {
    // Code goes here
});

unbind()和.off()方法都不能工作。

然而,.undelegate()方法可用于完全从事件中删除与当前选择器匹配的所有元素的处理程序:

$("body").undelegate(".dynamicTarget", "click")