如何在所有浏览器中生成右键单击事件

时间:2009-10-16 18:18:45

标签: javascript javascript-events dojo cross-browser right-click

一点背景:
我正在处理的应用程序为屏幕上的某些对象提供了右键单击上下文菜单。当前设计中每个对象都侦听右键单击,发送AJAX请求以获取该对象的上下文数据,使用该数据从Dojo 0.4.3创建PopupMenu2(我知道!),然后生成右键单击以启动Dojo菜单。

我正试图想出一种为所有浏览器生成右键单击事件的方法。目前,我们只支持IE并使用oncontextmenu事件。

限制:

  • 没有jQuery :(
  • 我无法预先加载屏幕上对象的所有数据来创建Dojo菜单并避免AJAX请求。

1 个答案:

答案 0 :(得分:4)

这应该让您开始生成右键单击事件。右键单击的关键是按钮参数:button = 2。

if (document.createEvent) {
  var rightClick = document.createEvent('MouseEvents');
  rightClick.initMouseEvent(
    'click', // type
    true,    // canBubble
    true,    // cancelable
    window,  // view - set to the window object
    1,       // detail - # of mouse clicks
    10,       // screenX - the page X coordinate
    10,       // screenY - the page Y coordinate
    10,       // clientX - the window X coordinate
    10,       // clientY - the window Y coordinate
    false,   // ctrlKey
    false,   // altKey
    false,   // shiftKey
    false,   // metaKey
    2,       // button - 1 = left, 2 = right
    null     // relatedTarget
  );
  document.dispatchEvent(rightClick);
} else if (document.createEventObject) { // for IE
  var rightClick = document.createEventObject();
  rightClick.type = 'click';
  rightClick.cancelBubble = true;
  rightClick.detail = 1;
  rightClick.screenX = 10;
  rightClick.screenY = 10;
  rightClick.clientX = 10;
  rightClick.clientY = 10;
  rightClick.ctrlKey = false;
  rightClick.altKey = false;
  rightClick.shiftKey = false;
  rightClick.metaKey = false;
  rightClick.button = 2;
  document.fireEvent('onclick', rightClick);
}

我建议谷歌搜索'document.createEvent'和'document.createEventObject',以获取有关Mozilla和MSDN站点的API的更多详细信息。

希望这有帮助!