메뉴 건너뛰기

2021.05.28 19:31

이벤트 흐름

조회 수 99 댓글 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 18277
403 오픈챌린지 5장 ces 2024.04.19 17
402 스타일 시트 객체 2 한성이 2022.08.09 32
401 css3의 프로퍼티와 7장 객체의 프로퍼티 1 한성이 2022.08.07 38
400 따옴표를 4중 5중으로 사용하는 방법에 대해 여쭙고 싶습니다. 입문한 사람 2020.04.07 40
399 border style 질문 2 궁그미 2020.07.28 41
398 76페이지 1 ramoss 2020.05.13 44
397 target프로퍼티 질문(페이지 428쪽) 2 한성이 2022.08.14 47
396 SRC와 SRDOC의 차이를 여쭙고 싶습니다. 입문한 사람 2020.04.07 48
395 인터넷익스플로러 질문이요 1 file 021 2020.04.10 48
394 p.254 3번문제 질문드립니다. 2 열심히 공부하는 독자 2020.08.14 48
393 value 속성 1 열심히 공부하는 독자 2020.09.04 48
392 예제 2-22 2개의 인라인 프레임을 가진 웹 페이지(91p) 2 file 코딩어렵다 2023.04.12 54
391 94p 그림2-4 질문 2 file 그냥초보 2020.04.15 55
390 계산기 문제 변형 문의 file Mikael 2022.12.13 56
389 윈도우 브라우저와 윈도우 탭 2 tc0712 2021.11.22 57
388 4장 171쪽 2 chu 2022.04.04 57
387 <script>태그의 위치 1 열심히 공부하는 독자 2020.08.15 58
386 브라우저 크기 변경 1 열심히 공부하는 독자 2020.08.27 59
385 length 프로퍼티 2 열공이 2022.05.21 59
384 [개정판] p.357 sibling 에 대한 설명 및 그림 8-7 1 질문 2022.09.02 59
목록
Board Pagination Prev 1 2 3 4 5 6 7 8 9 10 ... 21 Next
/ 21
위로