메뉴 건너뛰기

2021.05.28 20:31

이벤트 흐름

조회 수 99 댓글 1

안녕하세요 교수님!

 

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

p.addEventListener("mouseover",over);

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

필수는 아닌건가요?

 

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

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

?
  • ?
    관리자 2021.05.29 16: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.21 18175
401 span과 text-align : center; 에 관한 문제입니다. file 2019.10.15 278605
400 11장 6번 으엉 2019.11.27 187041
399 placeholder속성 1 khl 2017.04.08 85504
398 11장 6번 1 mj 2018.11.29 67040
397 웹 프로그래밍 책 답안지 1 mumu 2017.03.06 14036
396 실습문제 8-2 (3) 13412 2018.11.08 12320
395 살다 살다 답을 반쪽만 주는 책은 처음입니다 1 음음 2019.01.24 8842
394 Open Challenge 와 실습문제 자료 2 김원상 2017.04.29 7443
393 14장 예제 사라진 건가요 1 ... 2021.03.09 4077
392 localhost 관련 문의 3 소년정 2018.02.20 4032
391 페이지 247 에 있는 Open Challenge 05 의 CSS3로 태그 배치하기를 공부하고 있는데 질문드립니다. 1 file 워니고 2018.03.28 3845
390 ㅠㅠ..질문좀 드리겠습니다.. 1 은성 2017.04.18 3834
389 연습문제 답안지 2 vdncnck 2017.03.28 3215
388 짝수번 정답 3 idididid 2017.12.25 3101
387 8장 연습문제 실습문제 4장 2 student 2017.05.08 2850
386 10장 오픈챌린지 5 은성 2017.04.07 2242
385 open challenge 05 2 hardworking 2017.03.29 2202
384 5장 연습문제 홀수 번 질문 1 채XX 2019.06.17 1985
383 HTML을 열심히 공부중인 학생입니다 3 열심히 하자 2018.05.30 1962
목록
Board Pagination Prev 1 2 3 4 5 6 7 8 9 10 ... 21 Next
/ 21
위로