메뉴 건너뛰기

조회 수 98 댓글 1

var myImg = document.getElementById("myImg");
myImg.onload = function() {
var width = myImg.width;
}
myImg.src = "banana.png"
위의 코드에서 이미지로딩과 함수의 순서를 바꿔도 상관없지않나요?
항상 이미지로딩을 지시하기전에 onload리스너를 먼저 등록해야하는 이유라도 있나요?
myImg.src = "banana.png"
myImg.onload = function() {
var width = myImg.width;
}
이렇게 해도 문제가 없을것같아요. 어차피 이미지가 완전히 로딩된후에 함수가 실행되므로.

?
  • ?
    관리자 2019.08.20 17:22

    그렇지 않습니다. 413페이지의 본문을 다시 읽어보세요.

    다음 코드의 경우
    myImg.src = "banana.png" (1)
    myImg.onload = function() { (2)
    var width = myImg.width; (3)
    }

    (1)의 코드가 실행될 때, 이미지 로딩을 시작합니다.
    그런데 로딩의 속도가 빨라 (2)의 코드가 미처 실행되기 전에 로딩이 완료되어 load 이벤트가 발생할 수 있습니다.
    현재 이렇게 발생한 load 이벤트를 받아 줄 리스너가 아직 없는 상태입니다. (2)의 코드 실행이 완료되지 않았기 때문에.

    그러면 브라우저는 load 이벤트를 처리할 리스너가 있는 지 확인하고 없는 경우 load 이벤트를 제거합니다.
    그 후 (2)의 코드가 실행되지만, load 이벤트는 이미 사라진 상태이므로
    (1)의 과정에서 발생한 load 이벤트를 처리하지 못하게 되고
    (3)의 코드는 실행되지 않게 됩니다.

    그래서 자바스크립트 프로그램을 작성할 때, 어떤 경우든 이벤트 리스너의 등록이 먼지 이루어지도록 코딩하는 것이 매우 중요합니다.


QnA

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

List of Articles
번호 제목 글쓴이 날짜 조회 수
공지 읽어주세요! 연습문제 및 실습문제 정답 공개에 관한 공지입니다. file 관리자 2017.06.20 18304
243 9장 예제 9-10질문입니다. 2 file 삼오칠 2021.05.14 365
242 9장 오픈챌린지 답이 너무 궁금합니다. 1 범이 2017.05.10 1253
241 ; 가 쓰일 때를 여쭙고 싶습니다 2 file 입문한 사람 2020.04.07 141
240 ; 에 대해 질문드립니다 1 입문한 사람 2020.04.01 85
239 a<<b가 뭔가요? 1 2020.07.01 103
238 Atom은 IDE 리스트에서 삭제해주세요. 1 삼오칠 2023.04.15 84
237 border style 질문 2 궁그미 2020.07.28 41
236 ch1 이론문제 1번 2 새내기 2021.03.06 221
235 chapter5 오픈챌린지 5장 아예 모르겠어요.. 열심히해보자 2020.11.03 312
234 css3로 웹 페이지 꾸미기 3 file ㅇㅇ 2020.04.30 109
233 css3의 프로퍼티와 7장 객체의 프로퍼티 1 한성이 2022.08.07 38
232 div 와 pre 중에서 어떤 게 더 상위에 위치하나요? 1 file 입문한사람 2020.04.03 751
231 document.getElementBy~ 2 tc0712 2021.11.22 108
230 document.write 내부에서의 onclick 이벤트 선언에 대한 오류 1 tlqk 2019.11.24 445
229 DOM트리 질문 1 열심히 공부하는 독자 2020.08.17 76
228 form 태그 1 열공이 2023.01.31 88
227 form 태그와 웹서버 1 tc0712 2021.09.29 103
226 html5 태그 검사 2 열공이 2022.03.10 94
225 HTML5+CSS3+Javascript 웹 프로그래밍[수정판] 4 file Jenny 2021.09.25 519
224 html에 css작성할때 2 궁금이 2020.03.03 353
목록
Board Pagination Prev 1 ... 4 5 6 7 8 9 10 11 12 13 ... 21 Next
/ 21
위로