我有一些使用的代码dispatchEvent
模拟点击,同样的代码在 Chrome 中运行良好,但在 Firefox 中不起作用。这是代码:
var evt = document.createEvent("MouseEvents");
evt.initEvent("click",true,true);
jQuery("a:contains(Next)")[0].dispatchEvent(evt);
我单击一个加载另一个页面的链接,该页面在 Chrome 中加载正常,但当我在 Firebug 中运行此代码时,甚至当我将其作为书签执行时,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;
}
See W3C 鼠标事件类型
我还用法语写了一篇关于触发 DOM 事件;我想翻译起来很容易。
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)