How can I trigger a native Javascript event from a QUnit test?

后端 未结 2 1920
礼貌的吻别
礼貌的吻别 2021-01-06 05:31

I\'m working on a Javascript library that does not depend on jQuery, though I have jQuery and QUnit available in my tests. In the library, I attach an event to an element th

相关标签:
2条回答
  • 2021-01-06 06:12

    jQuery has its own event registration system, which is separate from the DOM's event registration. When we call $(something).click(), all registered jQuery handlers and the registered onclick handler will fire, but nothing else would. For example,

    document.body.addEventListener('click', function() { alert('event') }, false);
    document.body.onclick = function() { alert('onclick'); };      
    
    $('body').click(); // alerts "onclick"
    

    If you call document.body.onclick(), then only the second event will fire and alert "onclick". To get both events to fire, create an event object and dispatch it for the element in question - body in this case. You can find an example here. Unsurprisingly, IE uses a different mechanism to do the same and you need to call fireEvent.

    Here's a non cross-browser example for modern browsers (taken from the MDC article above),

    var clickEvent = document.createEvent('MouseEvents');
    clickEvent.initMouseEvent('click', true, true, window,
        0, 0, 0, 0, 0, false, false, false, false, 0, null);
    
    document.body.dispatchEvent(clickEvent);
    
    0 讨论(0)
  • 2021-01-06 06:15

    (not sure) jQuery uses it's own event system on top of the native event system. $(el).click() is invoked directly on that event system and not on the native system. (/not sure)

    document.getElementById('tab').onclick();
    

    Is the native equivalent, but you might want to check first if querying for the element actually finds the element. Are you initializing the QUnit tests when the dom is ready?

    Also, for attachEvent (IE) you need to prefix events with 'on'.

    tab.attachEvent('onclick', listenerFn);
    

    ps. actually I think that the missing prefix 'on' for the IE equivalent was the problem. Change it and test $().click() again.

    0 讨论(0)
提交回复
热议问题