JavaScript click event listener on class

后端 未结 5 994
悲&欢浪女
悲&欢浪女 2020-11-22 10:19

I\'m currently trying to write some JavaScript to get the attribute of the class that has been clicked. I know that to do this the correct way, I should use an event listene

5条回答
  •  囚心锁ツ
    2020-11-22 10:46

    This should work. getElementsByClassName returns an array Array-like object(see edit) of the elements matching the criteria.

    var elements = document.getElementsByClassName("classname");
    
    var myFunction = function() {
        var attribute = this.getAttribute("data-myattribute");
        alert(attribute);
    };
    
    for (var i = 0; i < elements.length; i++) {
        elements[i].addEventListener('click', myFunction, false);
    }
    

    jQuery does the looping part for you, which you need to do in plain JavaScript.

    If you have ES6 support you can replace your last line with:

        Array.from(elements).forEach(function(element) {
          element.addEventListener('click', myFunction);
        });
    

    Note: Older browsers (like IE6, IE7, IE8) don´t support getElementsByClassName and so they return undefined.


    EDIT : Correction

    getElementsByClassName doesnt return an array, but a HTMLCollection in most, or a NodeList in some browsers (Mozilla ref). Both of these types are Array-Like, (meaning that they have a length property and the objects can be accessed via their index), but are not strictly an Array or inherited from an Array. (meaning other methods that can be performed on an Array cannot be performed on these types)

    Thanks to user @Nemo for pointing this out and having me dig in to fully understand.

提交回复
热议问题