我想阻止标准的上下文菜单,并手动处理右键单击事件。
这是怎么做的?
我想阻止标准的上下文菜单,并手动处理右键单击事件。
这是怎么做的?
使用oncontextmenu
事件。
下面是一个例子:
<div oncontextmenu="javascript:alert('success!');return false;">
Lorem Ipsum
</div>
el.addEventListener('contextmenu', function(ev) {
ev.preventDefault();
alert('success!');
return false;
}, false);
不要忘记返回false,否则仍然会弹出标准上下文菜单。
如果要使用自己编写的函数而不是javascript:alert("Success!")
,请记住在函数和oncontextmenu
属性中都返回 false 。
我认为你正在寻找这样的东西:
function rightclick() {
var rightclick;
var e = window.event;
if (e.which) rightclick = (e.which == 3);
else if (e.button) rightclick = (e.button == 2);
alert(rightclick); // true or false, you can trap right click here by if comparison
}
( http://www.quirksmode.org/js/events_properties.html )
然后即使使用函数 rightclick() 使用 onmousedown (如果你想在整个页面上全局使用它,你可以这样做 <body onmousedown=rightclick(); >