>웹 프론트엔드 >JS 튜토리얼 >동일한 클래스의 여러 요소에 클릭 이벤트 리스너를 추가하는 방법은 무엇입니까?

동일한 클래스의 여러 요소에 클릭 이벤트 리스너를 추가하는 방법은 무엇입니까?

Mary-Kate Olsen
Mary-Kate Olsen원래의
2024-11-09 16:30:02679검색

How to Add Click Event Listeners to Multiple Elements with the Same Class?

동일한 클래스의 요소에 클릭 이벤트 리스너 추가

이 시나리오에서는 ID 삭제를 위한 목록 보기가 있고 이를 추가하려고 합니다. 클래스가 "삭제"인 모든 요소에 대한 확인 경고입니다. 그런데 클래스의 첫 번째 요소만 리스너를 받는 것처럼 보이는 문제가 발생했습니다.

해결 방법

이를 해결하려면 querySelectorAll을 사용해야 합니다. 쿼리선택기 대신. querySelectorAll은 지정된 클래스가 있는 모든 요소를 ​​포함하는 NodeList를 반환합니다.

var deleteLink = document.querySelectorAll('.delete');

이제 NodeList를 반복하고 각 요소에 이벤트 리스너를 추가할 수 있습니다.

for (var i = 0; i < deleteLink.length; i++) {
    deleteLink[i].addEventListener('click', function(event) {
        if (!confirm("sure u want to delete " + this.title)) {
            event.preventDefault();
        }
    });
}

또한 사용자가 삭제를 확인하지 않는 경우의 기본 작업입니다. 이렇게 하면 사용자가 명시적으로 계속하기로 선택한 경우에만 삭제가 실행됩니다.

ES6 개선

ES6에서는 Array.prototype.forEach를 사용하여 루프를 단순화할 수 있습니다. :

Array.from(deleteLinks).forEach(link => {
    link.addEventListener('click', event => {
        if (!confirm(`sure u want to delete ${this.title}`)) {
            event.preventDefault();
        }
    });
});

이 버전은 더 깔끔한 구문을 위해 템플릿 문자열(ES2015에 도입됨)을 활용합니다.

위 내용은 동일한 클래스의 여러 요소에 클릭 이벤트 리스너를 추가하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.