[英]How to disable mouse left click?
我想禁用鼠标左键单击。 我使用以下脚本但不起作用。
<h:form>
<a4j:commandButton value="TestButton" onclick="alert('button cliked')"/>
</h:form>
JavaScript是:
<script type="text/javascript">
document.captureEvents(Event.MOUSEDOWN | Event.MOUSEUP | Event.CLICK);
document.onmousedown = clickIE4;
document.onmouseup = clickIE4;
document.onclick = clickIE4;
function clickIE4()
{
return false;
}
</script>
帮我。 谢谢你的努力。
你错了。 您想要禁用按钮(enabled = false),而不是捕获鼠标单击。
使用该样式的处理程序时,从处理程序代码返回false
:
<a4j:commandButton value="TestButton" onclick="alert('button clicked'); return false;"/>
正如theatrus所说 ,但是,如果你的目标是禁用按钮,那么最好实际禁用按钮而不是阻止它的点击。 但就你的问题“如何禁用左键单击”而言,这就是答案。
更彻底的是,有两种不同的方法来附加事件处理程序:
DOM0(您使用的样式):从处理程序代码返回false
以停止事件(防止它冒泡到其他元素)并阻止默认操作:
<someElement onclick="return false;">
DOM2(使用JavaScript代码):DOM2处理程序通过addEventListener
(或IE上的attachEvent
)附加。 这是一个例子,假设一个id
“foo”的元素:
// Attaching:
var elm = document.getElementById("foo");
if (elm.attachEvent) {
elm.attachEvent("onclick", handler);
}
else if (elm.addEventListener) {
elm.addEventListener("click", handler, false);
}
// Handler:
function handler(event) {
// DOM standard is that `event` is an argument to the
// handler; IE uses a global event object instead.
// This line handles that.
event = event || window.event;
// Cancelling bubbling:
if (event.stopPropagation) {
// DOM standard
event.stopPropagation();
}
else {
// Older mechanism
event.cancelBubble = true;
}
// Preventing default action:
if (event.preventDefault) {
// DOM standard
event.preventDefault();
}
else {
// Older mechanism
event.returnValue = false;
}
}
一些参考资料:
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.