jQuery 의 delegate 흉내내기
제이쿼리에서는 부모를 지정한 다음 이벤트 발생 시 그 하위 태그가 지정된 셀렉터와 일치하면 발생시키는 기능으로,
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개
CJack
11년 전
좋은 정보감사합니다.
게시판 목록
프로그램
| 번호 | 제목 | 글쓴이 | 날짜 | 조회 |
|---|---|---|---|---|
| 7830 | 9년 전 | 388 | ||
| 7829 |
|
9년 전 | 566 | |
| 7828 | 9년 전 | 496 | ||
| 7827 | 9년 전 | 383 | ||
| 7826 | 9년 전 | 389 | ||
| 7825 | 9년 전 | 441 | ||
| 7824 | 9년 전 | 424 | ||
| 7823 | 9년 전 | 330 | ||
| 7822 | 9년 전 | 326 | ||
| 7821 | 9년 전 | 273 | ||
| 7820 | 9년 전 | 325 | ||
| 7819 |
|
10년 전 | 730 | |
| 7818 | 10년 전 | 355 | ||
| 7817 | 10년 전 | 467 | ||
| 7816 | 10년 전 | 375 | ||
| 7815 | 10년 전 | 576 | ||
| 7814 | 10년 전 | 404 | ||
| 7813 | 10년 전 | 341 | ||
| 7812 | 10년 전 | 352 | ||
| 7811 | 10년 전 | 368 | ||
| 7810 | 10년 전 | 517 | ||
| 7809 | 10년 전 | 445 | ||
| 7808 | 10년 전 | 317 | ||
| 7807 | 10년 전 | 369 | ||
| 7806 |
프로그래머7
|
10년 전 | 1311 | |
| 7805 | 10년 전 | 1238 | ||
| 7804 |
zahir1312
|
10년 전 | 751 | |
| 7803 |
|
10년 전 | 1350 | |
| 7802 | 10년 전 | 416 | ||
| 7801 | 10년 전 | 838 | ||
| 7800 | 10년 전 | 1069 | ||
| 7799 | 10년 전 | 511 | ||
| 7798 | 10년 전 | 471 | ||
| 7797 | 10년 전 | 467 | ||
| 7796 | 10년 전 | 310 | ||
| 7795 | 10년 전 | 463 | ||
| 7794 | 10년 전 | 492 | ||
| 7793 | 10년 전 | 1017 | ||
| 7792 | 10년 전 | 418 | ||
| 7791 | 10년 전 | 505 | ||
| 7790 | 10년 전 | 469 | ||
| 7789 |
fbastore
|
10년 전 | 1409 | |
| 7788 | 10년 전 | 501 | ||
| 7787 | 10년 전 | 362 | ||
| 7786 | 10년 전 | 523 | ||
| 7785 | 10년 전 | 537 | ||
| 7784 | 10년 전 | 605 | ||
| 7783 | 10년 전 | 412 | ||
| 7782 | 10년 전 | 455 | ||
| 7781 | 10년 전 | 868 | ||
| 7780 | 10년 전 | 789 | ||
| 7779 | 10년 전 | 757 | ||
| 7778 | 10년 전 | 324 | ||
| 7777 | 10년 전 | 416 | ||
| 7776 | 10년 전 | 417 | ||
| 7775 | 10년 전 | 360 | ||
| 7774 | 10년 전 | 608 | ||
| 7773 | 10년 전 | 348 | ||
| 7772 | 10년 전 | 682 | ||
| 7771 | 10년 전 | 337 | ||
| 7770 | 10년 전 | 620 | ||
| 7769 | 10년 전 | 339 | ||
| 7768 | 10년 전 | 559 | ||
| 7767 | 10년 전 | 1129 | ||
| 7766 | 10년 전 | 458 | ||
| 7765 | 10년 전 | 486 | ||
| 7764 |
잘살아보자
|
10년 전 | 339 | |
| 7763 |
|
10년 전 | 1406 | |
| 7762 |
Tosea
|
10년 전 | 1027 | |
| 7761 | 10년 전 | 615 | ||
| 7760 |
잘살아보자
|
10년 전 | 630 | |
| 7759 |
잘살아보자
|
10년 전 | 440 | |
| 7758 |
잘살아보자
|
10년 전 | 542 | |
| 7757 | 10년 전 | 1194 | ||
| 7756 |
ITBANK
|
10년 전 | 1230 | |
| 7755 | 10년 전 | 1907 | ||
| 7754 | 10년 전 | 1017 | ||
| 7753 | 10년 전 | 848 | ||
| 7752 | 10년 전 | 1357 | ||
| 7751 |
잘살아보자
|
10년 전 | 481 | |
| 7750 |
잘살아보자
|
10년 전 | 446 | |
| 7749 |
잘살아보자
|
10년 전 | 449 | |
| 7748 |
잘살아보자
|
10년 전 | 437 | |
| 7747 |
잘살아보자
|
10년 전 | 535 | |
| 7746 |
잘살아보자
|
10년 전 | 649 | |
| 7745 |
잘살아보자
|
10년 전 | 890 | |
| 7744 |
잘살아보자
|
10년 전 | 394 | |
| 7743 | 10년 전 | 922 | ||
| 7742 |
starbros
|
10년 전 | 803 | |
| 7741 |
잘살아보자
|
10년 전 | 624 | |
| 7740 |
잘살아보자
|
10년 전 | 490 | |
| 7739 |
잘살아보자
|
10년 전 | 446 | |
| 7738 |
잘살아보자
|
10년 전 | 502 | |
| 7737 |
잘살아보자
|
10년 전 | 461 | |
| 7736 |
잘살아보자
|
10년 전 | 478 | |
| 7735 |
잘살아보자
|
10년 전 | 814 | |
| 7734 |
잘살아보자
|
10년 전 | 408 | |
| 7733 |
잘살아보자
|
10년 전 | 515 | |
| 7732 |
잘살아보자
|
10년 전 | 667 | |
| 7731 |
잘살아보자
|
10년 전 | 588 |
댓글 작성
댓글을 작성하시려면 로그인이 필요합니다.
로그인하기