메뉴 건너뛰기

2021.05.28 19:31

이벤트 흐름

조회 수 16 댓글 1

안녕하세요 교수님!

 

402page에서 보면 하나의 DOM객체는 캡쳐 리스너와 버블 리스너를 모두 가질 수 있고 이벤트 리스너 등록할 때 캡쳐 리스너인지 버블 리스너인지 분명히 지정하여야 한다고 나와있는데 예제 9-3을 보면

p.addEventListener("mouseover",over);

로 리스너 등록할때 캡쳐나 버블 리스너에 대한 지정이 없거든요.

필수는 아닌건가요?

 

그리고 지금까지 앞장예제 실행시 html문서는 태그 선언 순서대로 실행을 하고 </html>을 만났을때 종료되는걸로만 이해를 했는데 이벤트 흐름에 다시 타켓 객체에서 거꾸로 window까지 이벤트 객체가 전파가 된다고 해서 좀 혼란스럽네요.

이벤트 선언이나 리스너 사용시에만 이런 캡쳐나 버블 2단계가 이루어지는 건지..

?
  • ?
    관리자 2021.05.29 15:54
    1. addEventListener()를 호출할 때 3번째 매개변수에 true나 false를 이용하여 캡쳐나 버블이냐를 지정해야 하지만,
    p.addEventListener("mouseover",over);와 같이 지정하지 않는 경우, 디폴트가 false로 전달되고, 버블 리스너 등록으로 처리됩니다.
    392 페이지에서 addEventListener()을 소개하는 마지막 부분을 참고하세요.
    "분명히 지정해야 한다"는 것에서 오해의 소지가 있군요. 이 부분의 글을 약간 수정하여 오해가 없도록 수정하겠습니다.

    2. 두번째 질문을 보죠.
    "html문서는 태그 선언 순서대로 실행을 하고 </html>을 만났을때 종료되는걸".. 이라고 헀는데,
    여기서 "실행"이라는 것은 곧 "브라우저가 HTML 문서를 읽고 DOM 트리를 만들고 화면에 출력하는 과정입니다."
    이벤트는 그 후 사용자의 마우스 입력이나 키보드 입력, 타이머 등에 의해 발생하고, 발생한 이벤트가 좀 전에 완성된 DOM 트리 위에서 흘러가는 것입니다.
    이 둘을 헷갈리지 마세요.

    "이벤트 선언이나 리스너 사용시에만 이런 캡쳐나 버블 2단계가 이루어지는 건지.." 라는 질문에 대해서 보면,
    이와 관계 없이 마우스나 키보드가 입력되면 이벤트가 발생합니다. 그리고 웹브라우저가 캡쳐 단계에서 버블 단계를 거쳐 이벤트를 흘려보냅니다.
    그런데 이벤트 리스너가 만들어져 있지 않다면 이벤트는 처리되지 않고 사라지게 됩니다.
    결론은, 이벤트 리스너가 만들어져 있는 지 여부와 관계없이 이벤트가 발생하면 이벤트 캡쳐 단계 그리고 다시 버블 단계로 이벤트가 흘러가는 것은 사실입니다.

QnA

공부하면서 궁금했던 것을 질문해보세요.

List of Articles
번호 제목 글쓴이 날짜 조회 수
공지 읽어주세요! 연습문제 및 실습문제 정답 공개에 관한 공지입니다. file 관리자 2017.06.20 11941
344 9 - 15 코드 개선 질문있습니다. 1 new killchain 2021.06.17 4
343 6장 실습문제 4번 1 김성준 2021.06.16 8
342 6장 OPEN challenge 1 초보 2021.06.09 26
341 9장 실습문제 10번 질문이요 2 mmii 2021.06.06 44
340 6장 예제 6-2 질문 1 릴릴 2021.05.31 30
339 교과서 13장 연습문제 1 알고싶어요 2021.05.29 47
» 이벤트 흐름 1 궁금이 2021.05.28 16
337 8장 실습문제 8번 질문이요! 3 mmii 2021.05.28 67
336 14장 소스코드 제공에 대해 질문합니다. 1 질문자 2021.05.25 30
335 10장 예제 10-8에 오류가 있습니다. 1 file 삼오칠 2021.05.22 87
334 9장 예제 9-10질문입니다. 1 file 삼오칠 2021.05.14 88
333 6장 openchallenge 1 ㅇㅇ 2021.05.06 70
332 명품 수정판 HTML5+ CSS3+ Javascript 웹 프로그래밍 p.74 메타 데이터 <meta> 문의 1 mikael 2021.05.06 36
331 오류 - 6장 3.식과 연산자 - 비트 논리 연산 1 김성필 2021.04.27 43
330 4장 예제 4-17질문입니다. 1 file Escui 2021.04.22 54
329 [명품 html5+ css3+ javascript 웹 프로그래밍 수정판] 1장 실습문제 4번 질문합니다... 2 file 나능냐공도리 2021.04.17 105
328 명품 html5+ 수정판 p.89 예제 2-21 파일 다운로드 링크 만들기 실행 오류 문의 1 file mikael 2021.04.15 38
327 명품 HTML5+ 수정판 2장 4번 문제 문의 1 file mikael 2021.04.14 56
326 명품 html5+ css3+ javascript 웹 프로그래밍 수정판 문제 실행 오류 문의 1 file mikael 2021.04.14 36
325 2-21 예제 3 file Iwanteating 2021.03.25 90
목록
Board Pagination Prev 1 2 3 4 5 6 7 8 9 10 ... 18 Next
/ 18
위로