我有一些代码使用dispatchEvent
来模拟点击,同样的代码在Chrome中运行良好,但在Firefox中不起作用。这是代码:
var evt = document.createEvent("MouseEvents");
evt.initEvent("click",true,true);
jQuery("a:contains(Next)")[0].dispatchEvent(evt);
我点击了一个加载另一个页面的链接,该页面在Chrome中加载良好,但当我在Firebug中运行此代码时,甚至当我将其作为bookmarklet执行时,Firefox绝对不会做任何事情。我还尝试过通过设置MDC文档中显示的所有选项进行事件初始化的长形式,但这没有任何作用。我到底做错了什么?
由于您的事件看起来是鼠标事件,因此您可以尝试使用鼠标事件,如以下示例:
var oEvt = (document.createEvent)? document.createEvent('MouseEvents') : document.createEventObject();
// W3C
if (oEvt.initMouseEvent)
oEvt.initMouseEvent(
/* type*/ 'mouseup',
/* bubble*/ true,
/* cancel*/ true,
/* AbstractView*/ window,
/* detail */ 10,
/* screenX */ 20,
/* screenY */ 30,
/* clientX */ 40,
/* clientY */ 50,
/* ctrlKey */ false,
/* altKey */ false,
/* shiftKey */ true,
/* metaKey */ false,
/* button */ 0,
/* relatedTarget*/ null ) ;
// MSIE
else {
var oEvt = document.createEventObject();
oEvt.detail = 10;
oEvt.screenX = 20;
oEvt.screenY = 30;
oEvt.clientX = 40;
oEvt.clientY = 50;
oEvt.ctrlKey = false;
oEvt.altKey = false;
oEvt.shiftKey = true;
oEvt.metaKey = false;
oEvt.button = 0;
oEvt.relatedTarget = null;
}
请参阅W3C鼠标事件类型
我还用法语写了一篇关于激发DOM事件的教程;我想翻译它很容易。
这是Firefox中的一个错误,请参阅:
https://bugzilla.mozilla.org/show_bug.cgi?id=395917
恐怕我不知道该怎么办。