"일꾼이 일을 잘하려면 먼저 도구를 갈고 닦아야 한다." - 공자, 『논어』.
첫 장 > 프로그램 작성 > 배경 이미지가 로드되었는지 확실하게 확인하는 방법은 무엇입니까?

배경 이미지가 로드되었는지 확실하게 확인하는 방법은 무엇입니까?

2024년 11월 24일에 게시됨
검색:778

How to Reliably Check if a Background Image Has Loaded?

배경 이미지 로더 사용

body 태그에 배경 이미지를 설정하여 배경 이미지가 로드되었는지 확인하려고 합니다. 그런 다음 load() 함수를 사용합니다. 그러나 이 접근 방식은 배경 이미지에는 효과적이지 않습니다.

배경 이미지가 완전히 로드되었는지 확인하려면 다음과 같은 다른 기술을 활용할 수 있습니다.

$('<img/>').attr('src', 'http://picture.de/image.png').on('load', function() {
   $(this).remove(); // prevent memory leaks
   $('body').css('background-image', 'url(http://picture.de/image.png)');
});

이 메소드는 메모리에 새 이미지를 생성하고 해당 이미지에 로드 이벤트 리스너를 연결합니다. 이미지가 로드되면 로드 이벤트가 트리거되고 배경 이미지가 body 태그에 설정됩니다.

바닐라 JavaScript에서는 다음과 같이 구현할 수 있습니다.

var src = 'http://picture.de/image.png';
var image = new Image();
image.addEventListener('load', function() {
   body.style.backgroundImage = 'url('   src   ')';
});
image.src = src;

이미지 로딩을 처리하고 promise를 반환하는 추상화된 함수를 만들 수도 있습니다.

function load(src) {
    return new Promise((resolve, reject) => {
        const image = new Image();
        image.addEventListener('load', resolve);
        image.addEventListener('error', reject);
        image.src = src;
    });
}

const image = 'http://placekitten.com/200/300';
load(image).then(() => {
   body.style.backgroundImage = `url(${image})`;
});

이 접근 방식을 사용하면 배경 이미지 로드 완료를 안정적으로 확인할 수 있으며 이미지가 완전히 로드된 후에만 코드가 실행되도록 할 수 있습니다.

최신 튜토리얼 더>

부인 성명: 제공된 모든 리소스는 부분적으로 인터넷에서 가져온 것입니다. 귀하의 저작권이나 기타 권리 및 이익이 침해된 경우 자세한 이유를 설명하고 저작권 또는 권리 및 이익에 대한 증거를 제공한 후 이메일([email protected])로 보내주십시오. 최대한 빨리 처리해 드리겠습니다.

Copyright© 2022 湘ICP备2022001581号-3