메뉴 건너뛰기

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 18281
343 배경슬라이드가 뭔지 추가설명하겠습니다 2 hansung 2019.06.27 92
342 p.469 실습 5번문제 4 열심히 공부하는 독자 2020.08.29 92
341 예제 2-18 1 새싹 2018.04.18 94
340 예제코드 크롬 브라우저실행 1 2018.09.17 94
339 html5 태그 검사 2 열공이 2022.03.10 94
338 웹서버와 클라이언트 2 tc0712 2021.09.14 95
337 오타제보합니다. 1 컴퓨터공학생 2020.08.30 96
336 303p. 12번에 2질문 드립니다 1 2020.10.15 96
335 예제4-5 질문드립니다. 3 초보 2020.04.27 97
334 교재 413page 질문입니다. 1 ㅁㅇㄻㄴㅇㄹ 2019.08.20 98
» 이벤트 흐름 1 궁금이 2021.05.28 99
332 예제 13-9 질문드립니다. 4 열심히 공부하는 독자 2020.09.12 100
331 2-26 오디오 삽입 모바일 문의 2 한수연 2017.12.12 101
330 교재403page 예제9-8 코드 질문입니다. 1 asdf 2019.08.19 101
329 예제 9-8 질문입니다. 2 모르겠어요 2020.07.31 101
328 몽구스 웹서버가 뭔가요? 1 안녕하세요 2020.08.16 101
327 캔버스 관련 질문 1 원그리기 2021.08.22 101
326 웹 워커 13-7 결과 55가 출력되지 않습니다. 1 chg115 2021.12.03 101
325 예제 2-18 1 file 새싹 2018.04.18 103
324 책을 종이책으로 구매했는데 1 ddd 2024.03.21 103
목록
Board Pagination Prev 1 ... 2 3 4 5 6 7 8 9 10 ... 21 Next
/ 21
위로