在 safari 中,似乎右键单击时将焦点赋予上下文菜单,因此上下文菜单接收 mouseup 事件而不是 P 元素。至于解决方案,您可以检测鼠标按钮以防止它在右键单击时运行。除非您想处理自定义上下文菜单,否则右键单击事件很混乱。
如果您希望鼠标右键单击时触发 mouseup 事件在 Safari 中工作,则需要通过将此属性添加到 P 元素来禁用上下文菜单:
oncontextmenu="return false">
还可以检测左键单击是否触发了事件(通常是您要处理的按钮):
function mouse_handler(event) {
var evt=window.event||event;
var button = evt.which || evt.button;
if (button == 1) { // if left mouse button
// handle the event
}
}
在 w3schools 的示例中,它会导致如下所示:
function myFunction(elmnt,clr,event)
{
var evt=window.event||event;
var button = evt.which || evt.button;
if (button == 1) { // if left mouse button
elmnt.style.color=clr;
}
}
然后在函数调用中传递事件:
<p onmousedown="myFunction(this,'red',event)" onmouseup="myFunction(this,'green',event)">