对于一个网站,我想在用户“长按”屏幕时显示自定义上下文菜单。我在代码中创建了一个jQuery Longclick侦听器来显示自定义上下文菜单。显示了上下文菜单,但也显示了 iPad 的默认上下文菜单!我试图通过preventDefault()
在我的监听器中添加一个事件来防止这种情况,但这不起作用:
function showContextMenu(e){
e.preventDefault();
// code to show custom context menu
}
$("#myId").click(500, showContextMenu);
问题
- 你能阻止 iPad 的默认上下文菜单显示吗?
- 可以通过使用 jQuery Longclick 插件来完成吗?
Longclick 插件对 iPad 有一些特定的处理(假设通过它的源代码片段):
if (!(/iphone|ipad|ipod/i).test(navigator.userAgent)){
$(this)
.bind(_mousedown_, schedule)
.bind([_mousemove_, _mouseup_, _mouseout_, _contextmenu_].join(' '), annul)
.bind(_click_, click)
}
所以我假设这回答了我的第二个问题(假设插件使用了正确的事件)。