3

我有一些dispatchEvent用于模拟点击的代码,相同的代码在 Chrome 中运行良好,但在 Firefox 中不起作用。这是代码:

var evt = document.createEvent("MouseEvents");
evt.initEvent("click",true,true);
jQuery("a:contains(Next)")[0].dispatchEvent(evt);

我正在单击一个加载另一个页面的链接,并且该页面在 Chrome 中加载正常,但是当我在 Firebug 中运行此代码时,甚至当我将其作为书签执行时,Firefox 完全没有做任何事情。我还通过设置 MDC 文档中显示的所有选项尝试了长形式的事件初始化,但这并没有做任何事情。我在这里到底做错了什么?

4

2 回答 2

3

由于您的事件看起来是鼠标事件,您可能宁愿尝试使用鼠标事件,例如以下示例:

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 事件的教程;我想翻译它很容易。

于 2011-06-25T00:36:30.680 回答
0

这是 Firefox 中的一个错误,请参见:

https://bugzilla.mozilla.org/show_bug.cgi?id=395917

恐怕我不知道有什么办法可以绕过它。

于 2014-04-24T12:15:03.150 回答