You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
@gmlwo530 안녕하세요. 좋은 질문 감사드립니다.
위 예제에서 모든 내용을 그대로 치시되 제일 위에 있던 Inputs관련 코드는 빼는게 원래 의도한 코드긴 합니다.
// 아래 코드는 빼야합니다.varinputs=document.querySelectorAll('input');inputs.forEach(function(input){input.addEventListener('click',function(event){alert('clicked');});});
얘기 해 주신 것처럼 같은 코드가 2번 실행되는거라 성능은 당연히 조금은 더 안좋겠죠 ?
아 그리고 alert가 2번 실행되는 또다른 이유는 li내부 태그가 Input이어서 이벤트를 한번 더 전달해서 그렇습니다.
참고할만한 CodeSandbox 첨부합니다.
@snowjang24 가 07월 22일 스터디에서
이벤트 위임은 이벤트 캡처링의 일부가 아닌가?
라는 질문에 대한 답변입니다.( 혹시 질문이 틀렸다면, 정정 해 주세요.)
먼저 답변은
이벤트 위임은 하위 요소에 각각 이벤트를 붙이지 않고 상위 요소에서 하위 요소의 이벤트를 제어하는 방식
이라고 정의 할 수 있습니다.위 방식대로라면 ul 안에 li 들은 모두 클릭시에 clicked 라는 alert이 뜨게 됩니다.
하지만, 만약 위 코드처럼 동적으로 li가 증가한다면, script 태그의 내용이 모든 inputs을 잡지는 못 하겠죠.
이때 필요한 것이 ul에 모든 이벤트 발생을 위임하여 동적 생성에도 대응 할 수 있도록 하는 것입니다.
즉, li에서 발생하는 이벤트 버블링을 부모 객체가 캐치 할 수 있도록 하는 것입니다.
물론 li에다 일일히 이벤트를 달아주는 방법도 있겠지만, 이보다는 이벤트 위임이 코드 가독성과 성능 면에서 유용합니다.
이렇게 말입니다!
추가 질문이 있으실 것 같은데, 여기에 더 달아주세요.
The text was updated successfully, but these errors were encountered: