테스트 사이트 - 개발 중인 베타 버전입니다

jQuery 의 delegate 흉내내기

· 11년 전 · 1136 · 1

제이쿼리에서는 부모를 지정한 다음 이벤트 발생 시 그 하위 태그가 지정된 셀렉터와 일치하면 발생시키는 기능으로, 

Ajax 등의 동적으로 바뀐 컨텐츠에도 대응이 가능하고 성능도 좋다고 알려져 있습니다. 

 

그렇다면 이 스크립트의 원리는 무엇인가요? 

간단합니다. 부모에게 이벤트를 줍니다. 그리고 이벤트 핸들러를 아래와 같이 만듭니다. 

 

function clickEventDelegate(e){ 

    var e = e || window.event; //이벤트 객체를 받아냅니다. 

    var target = e.target || e.srcElement; //이벤트가 발생시킨 원래 요소를 가져옵니다. 

    if(target.nodeName == 'LI'){ //발생시킨 요소가 <li> 태그이면 

        childEventHandler.call(target, e); //해당 이벤트를 실행합니다. 

    } 

 

여기서 한가지 주의해야 할 점이 있습니다. 

이벤트를 발생시킨 요소에 이벤트가 있을 때, 

return false; 반환하거나, event.stopPropagation() 메소드 또는 event.cancelBubble = true; 를 실행하면 

자식에서 부모에게 이벤트를 전달하지 않게 되기 때문에 

부모에서 캡쳐하지 못합니다. 이는 제이쿼리라도 마찬가지입니다. 

 

댓글 작성

댓글을 작성하시려면 로그인이 필요합니다.

로그인하기

댓글 1개

좋은 정보감사합니다.

게시글 목록

번호 제목
27925
27922
6972
19602
19601
19599
6961
30941
19597
19596
19595
19594
30939
19593
6959
6957
6953
27920
19592
19591
19590
6949
6947
20826
20823
19589
27913
27912
19588
20822
19587
19586
27887
20819
27883
19585
19584
19583
19582
19581
19580
6945
24622
19578
6938
6935
27880
20818
19575
20815
20812
20809
6932
6931
6929
19571
19570
20802
27877
20797
6923
20795
6918
6914
20789
6899
27860
6898
27856
6895
6891
6890
6881
6874
27852
6860
6857
19569
19565
19564
27844
19563
24617
19554
6854
19553
19531
6850
6848
27842
6846
6842
6839
6834
6829
6824
6820
27839
6818
19529