>  기사  >  웹 프론트엔드  >  CSS, JavaScript 및 Ajax를 사용하여 효율적인 이미지 preloading_javascript 기술 달성

CSS, JavaScript 및 Ajax를 사용하여 효율적인 이미지 preloading_javascript 기술 달성

WBOY
WBOY원래의
2016-05-16 17:19:44923검색

방법 1: CSS와 JavaScript를 사용하여 사전 로드 구현

CSS, JavaScript 및 이 둘의 다양한 조합을 사용하는 등 이미지 사전 로드를 구현하는 방법에는 여러 가지가 있습니다. 이러한 기술은 다양한 설계 시나리오에 따라 해당 솔루션을 설계할 수 있으며 매우 효율적입니다.
CSS만 사용하면 이미지를 쉽고 효율적으로 미리 로드할 수 있습니다.

코드 복사 코드는 다음과 같습니다.

#preload-01 { background: url(http://domain.tld/image-01.png) no-repeat -9999px -9999px }
#preload; -02 { 배경: url (http://domain.tld/image-02.png) no-repeat -9999px -9999px }
#preload-03 { 배경: url(http://domain.tld/ image-03.png) no-repeat -9999px -9999px }

이 세 가지 ID 선택기를 (X)HTML 요소에 적용하면 다음의 배경 속성을 통해 이미지를 화면 외부에 미리 로드할 수 있습니다. 배경에 CSS. 이러한 이미지의 경로가 동일하게 유지되는 한, 브라우저는 웹 페이지의 다른 곳에서 호출될 때 렌더링 프로세스 중에 미리 로드된(캐시된) 이미지를 사용합니다. 간단하고 효율적이며 JavaScript가 필요하지 않습니다.
이 방법은 효율적이지만 아직 개선의 여지가 있습니다. 이 방법을 사용하여 로드된 이미지는 페이지의 다른 콘텐츠와 함께 로드되므로 페이지의 전체 로드 시간이 늘어납니다. 이 문제를 해결하기 위해 페이지가 로드될 때까지 사전 로드 시간을 지연시키는 일부 JavaScript 코드를 추가했습니다. 코드는 다음과 같습니다.
코드 복사 코드는 다음과 같습니다.

// better 이미지 미리 로드 @ http://perishablepress.com/ press/2009/12/ 28/3-ways-preload-images-css-javascript-ajax/
function preloader() {
if (document.getElementById) {
document. getElementById("preload-01 ").style.Background = "url(http://domain.tld/image-01.png) no-repeat -9999px -9999px"
document.getElementById("preload-02 ").style.Background = "url(http://domain.tld/image-02.png) no-repeat -9999px -9999px";
document.getElementById("preload-03").style.Background = "url(http: //domain.tld/image-03.png) no-repeat -9999px -9999px";
}
}
function addLoadEvent(func) {
var oldonload = window.onload;
if (window.onload 유형 != 'function') {
window.onload = func
} else {
window.onload = function() {
if; (oldonload) {
oldonload();
}
func();
}
}
}
addLoadEvent(프리로더)

스크립트 시작 부분에서 클래스 선택기를 사용하여 요소를 가져오고 배경 속성을 설정하여 다른 이미지를 미리 로드합니다.
스크립트의 두 번째 부분에서는 페이지가 로드될 때까지 preloader() 함수의 로딩 시간을 지연시키기 위해 addLoadEvent() 함수를 사용합니다.
사용자의 브라우저에서 JavaScript가 제대로 실행되지 않으면 어떻게 되나요? 매우 간단합니다. 페이지에서 이미지를 호출하면 이미지가 미리 로드되지 않습니다.

방법 2: JavaScript만 사용하여 preloading 구현

위 방법은 때로는 매우 효율적이지만 실제 구현 과정에서 너무 많은 시간을 소비한다는 것을 점차 알게 되었습니다. . 대신, 이미지 사전 로딩을 위해 순수한 JavaScript를 사용하는 것을 선호합니다. 다음은 모든 최신 브라우저에서 훌륭하게 작동하는 두 가지 사전 로드 방법입니다.

JavaScript 코드 스니펫 1

필요한 이미지의 경로와 이름만 편집하고 로드하기만 하면 구현이 쉽습니다.
코드 복사 코드는 다음과 같습니다.


이 방법은 특히 많은 수의 이미지를 미리 로드하는 데 적합합니다. 내 갤러리 웹사이트는 이 기술을 사용하여 50개 이상의 이미지를 미리 로드합니다. 이 스크립트를 로그인 페이지에 적용하면 사용자가 로그인 ID를 입력하자마자 대부분의 갤러리 이미지가 미리 로드됩니다.

JavaScript Code Snippet 2

이 방법은 위의 방법과 유사하며 원하는 만큼의 이미지를 미리 로드할 수도 있습니다. 웹 페이지에 다음 스크립트를 추가하고 프로그램 지침에 따라 편집하십시오.
코드 복사 코드는 다음과 같습니다.


보시다시피 이미지를 로드할 때마다 "img1 = new Image();"와 같은 변수를 만들고 이미지 소스 주소를 선언해야 합니다. "img3.src = "../path /to/image-003.gif";"로. 이 패턴을 사용하면 필요한 만큼 이미지를 로드할 수 있습니다.
이 방법을 다시 개선했습니다. 이 스크립트를 함수로 래핑하고 addLoadEvent()를 사용하여 페이지가 로드될 때까지 사전 로드 시간을 지연시킵니다.
코드 복사 코드는 다음과 같습니다.

function preloader() {
if (document.images) {
var img1 = new Image();
var img2 = new Image()
var img3 = new Image()
img1.src = "http:/ /domain.tld/path/to/image-001.gif";
img2.src = "http://domain.tld/path/to/image-002.gif";
img3.src = "http: //domain.tld/path/to/image-003.gif";
}
}
function addLoadEvent(func) {
var oldonload = window.onload; if (typeof window.onload != 'function') {
window.onload = func
} else {
window.onload = function() {
if (oldonload) {
oldonload() ;
}
func();
}
}
addLoadEvent(preloader)

방법 3: Ajax를 사용하여 Preloading 구현

위에 제시한 방법은 별로 멋지지 않은 것 같으니 이제 Ajax를 사용하여 이미지 Preloading을 구현하는 방법을 살펴보겠습니다. 이 방법은 DOM을 사용하여 이미지를 미리 로드할 뿐만 아니라 CSS, JavaScript 및 기타 관련 항목도 미리 로드합니다. JavaScript를 직접 사용하는 것보다 Ajax를 사용하는 것의 장점은 JavaScript 및 CSS를 로드해도 현재 페이지에 영향을 미치지 않는다는 것입니다. 방법은 간단하고 효율적입니다.


코드 복사
코드는 다음과 같습니다. window.onload = function() { setTimeout(function() {
// JS 및 CSS를 요청하는 XHR
var xhr = new XMLHttpRequest();
xhr.open('GET', 'http://domain. tld/preload .js');
xhr.send('');
xhr = new XMLHttpRequest()
xhr.open('GET', 'http://domain.tld/preload .css' );
xhr.send('');
// 이미지 미리 로드
새 Image().src = "http://domain.tld/preload.png"; }, 1000 );
};


위 코드는 "preload.js", "preload.css" 및 "preload.png"를 미리 로드합니다. 1000밀리초 시간 제한은 스크립트가 중단되어 일반 페이지에 기능적 문제가 발생하는 것을 방지하기 위한 것입니다.
다음으로 JavaScript를 사용하여 로딩 프로세스를 구현하는 방법을 살펴보겠습니다.



코드 복사
코드는 다음과 같습니다. window.onload = function() { setTimeout(function() { // 에 대한 참조
var head = document.getElementsByTagName('head' )[0] ;
// 새로운 CSS
var css = document.createElement('link')
css.type = "text/css"
css.rel = "stylesheet ";
css.href = "http://domain.tld/preload.css";
// 새로운 JS
var js = document.createElement("script");
js .type = " text/javascript";
js.src = "http://domain.tld/preload.js"
// JS 및 CSS 사전 로드
head.appendChild(css); 🎜>head.appendChild(js);// 이미지 미리 로드
new Image().src = "http://domain.tld/preload.png"
},
};


여기에서는 DOM을 통해 세 개의 요소를 생성하여 세 개의 파일을 미리 로드합니다. 위에서 언급했듯이 Ajax에서는 파일 로딩이 로딩 페이지에 적용되지 않습니다. 이러한 관점에서 Ajax 메소드는 JavaScript보다 우수합니다.
성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.