addEventListener on NodeList

前端 未结 8 2243
轮回少年
轮回少年 2020-11-30 07:12

Does NodeList support addEventListener. If not what is the best way to add EventListener to all the nodes of the NodeList. Currently I am using the code snippet as show be

8条回答
  •  一向
    一向 (楼主)
    2020-11-30 07:47

    There is no way to do it without looping through every element. You could, of course, write a function to do it for you.

    function addEventListenerList(list, event, fn) {
        for (var i = 0, len = list.length; i < len; i++) {
            list[i].addEventListener(event, fn, false);
        }
    }
    
    var ar_coins = document.getElementsByClassName('coins');
    addEventListenerList(ar_coins, 'dragstart', handleDragStart); 
    

    or a more specialized version:

    function addEventListenerByClass(className, event, fn) {
        var list = document.getElementsByClassName(className);
        for (var i = 0, len = list.length; i < len; i++) {
            list[i].addEventListener(event, fn, false);
        }
    }
    
    addEventListenerByClass('coins', 'dragstart', handleDragStart); 
    

    And, though you didn't ask about jQuery, this is the kind of stuff that jQuery is particularly good at:

    $('.coins').on('dragstart', handleDragStart);
    

提交回复
热议问题