찾다
웹 프론트엔드JS 튜토리얼이미지 사전 로딩을 달성하는 세 가지 주요 방법 및 장점과 단점 분석_javascript 기술

이미지를 미리 로드하는 것은 사용자 경험을 향상시키는 좋은 방법입니다. 브라우저에 미리 로드된 이미지를 통해 방문자는 사이트를 원활하게 탐색하고 엄청나게 빠른 로딩 시간을 즐길 수 있습니다. 이는 이미지가 큰 비율을 차지하는 이미지 갤러리 및 웹 사이트에 매우 유용합니다. 이는 이미지가 빠르고 원활하게 게시되도록 보장하고 사용자가 웹 사이트 콘텐츠를 탐색할 때 더 나은 사용자 경험을 얻는 데도 도움이 됩니다. 이 기사에서는 웹 사이트 성능과 유용성을 향상시키는 세 가지 사전 로딩 기술을 공유합니다.

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

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

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

#preload-01 { 배경: 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 코드를 추가했습니다. 코드는 다음과 같습니다.

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

// 더 나은 이미지 미리 로드 @ http://perishablepress.com/press/2009/12/28/3-ways-preload-images-css-javascript-ajax/">http://perishablepress.com/press/2009/12/28/3-ways-preload-images-css-javascript-ajax/">http: //perishablepress.com/press/2009/12/28/3-ways-preload-images-css-javascript-ajax/> 함수 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";     
}  

함수 addLoadEvent(func) {
var oldonload = window.onload
If (typeof window.onload != 'function') {
          window.onload = func;                    } else {  
Window.onload = 함수() {
If (oldonload) {
                       oldonload();                                    ~                 func();                                                    ~ }  

addLoadEvent(프리로더)

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

방법 2: JavaScript만 사용하여 사전 로드 구현

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

자바스크립트 스니펫 1
필요한 이미지의 경로와 이름을 편집하고 로드하기만 하면 쉽게 구현할 수 있습니다.

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

~ 함수 미리 로드() {
for (i = 0; i 이미지[i] = 새 이미지()
이미지[i].src = preload.arguments[i]
| ~                   사전 로드(                                        "
http://domain.tld/gallery/image-001.jpg
", "
"
http://domain.tld/gallery/image-002.jpg
", "
"http://domain.tld/gallery/image-003.jpg"
                                                                ~

이 방법은 특히 많은 수의 이미지를 미리 로드하는 데 적합합니다. 내 갤러리 웹사이트는 이 기술을 사용하여 50개 이상의 이미지를 미리 로드합니다. 이 스크립트를 로그인 페이지에 적용하면 사용자가 로그인 ID를 입력하자마자 대부분의 갤러리 이미지가 미리 로드됩니다.
JavaScript 코드 스니펫 2
이 방법은 위의 방법과 유사하며 원하는 만큼의 이미지를 미리 로드할 수도 있습니다. 웹 페이지에 다음 스크립트를 추가하고 프로그램 지침에 따라 편집하십시오.


코드 복사


코드는 다음과 같습니다.


                                                                                  img1 = 새 이미지()
                      img2 = 새 이미지()
                      img3 = 새 이미지()
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
";                }                                                         

보시다시피 이미지를 로드할 때마다 "img1 = new Image();"와 같은 변수를 생성하고 "img3.src = "../path/to/image-003.gif";". 이 모드를 참고하면 필요한 만큼 이미지를 불러올 수 있습니다.
우리는 이 방법을 더욱 개선했습니다. 이 스크립트를 함수로 래핑하고 addLoadEvent()를 사용하여 페이지가 로드될 때까지 사전 로드 시간을 지연시킵니다.


코드 복사

코드는 다음과 같습니다.

"; img3.src = "
http://domain.tld/path/to/image-003.gif
"; }  

함수 addLoadEvent(func) {
var oldonload = window.onload
If (typeof window.onload != 'function') {
          window.onload = func;                    } else {             window.onload = function() {                                                                                       ~                       window.onload = function()            If (oldonload) {                        oldonload();                                    ~                 func();                                                    ~ }  
addLoadEvent(프리로더)

방법 3: Ajax를 사용하여 사전 로드 구현


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





코드 복사


코드는 다음과 같습니다.

window.onload = function() {
setTimeout(함수() {
                 // 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 = "                                                                  }, 1000)
};


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



코드 복사

코드는 다음과 같습니다.

window.onload = function() {

";                                          
             // 새로운 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
"
     
}, 1000)
     
};
여기에서는 DOM을 통해 세 개의 요소를 생성하여 세 개의 파일을 미리 로드합니다. 위에서 언급했듯이 Ajax에서는 파일 로딩이 로딩 페이지에 적용되지 않습니다. 이러한 관점에서 Ajax 메소드는 JavaScript보다 우수합니다.

자, 이번 글에서는 먼저 이미지 프리로딩 기술을 구현하는 세 가지 방법을 모두 알고 계시는데, 어느 것이 더 효율적인지 다들 아실 거라 생각하니, 직접 프로젝트에 적용해보세요.
성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
利用CSS怎么创建渐变色边框?5种方法分享利用CSS怎么创建渐变色边框?5种方法分享Oct 13, 2021 am 10:19 AM

利用CSS怎么创建渐变色边框?下面本篇文章给大家分享CSS实现渐变色边框的5种方法,希望对大家有所帮助!

css ul标签怎么去掉圆点css ul标签怎么去掉圆点Apr 25, 2022 pm 05:55 PM

在css中,可用list-style-type属性来去掉ul的圆点标记,语法为“ul{list-style-type:none}”;list-style-type属性可设置列表项标记的类型,当值为“none”可不定义标记,也可去除已有标记。

css与xml的区别是什么css与xml的区别是什么Apr 24, 2022 am 11:21 AM

区别是:css是层叠样式表单,是将样式信息与网页内容分离的一种标记语言,主要用来设计网页的样式,还可以对网页各元素进行格式化;xml是可扩展标记语言,是一种数据存储语言,用于使用简单的标记描述数据,将文档分成许多部件并对这些部件加以标识。

css3怎么实现鼠标隐藏效果css3怎么实现鼠标隐藏效果Apr 27, 2022 pm 05:20 PM

在css中,可以利用cursor属性实现鼠标隐藏效果,该属性用于定义鼠标指针放在一个元素边界范围内时所用的光标形状,当属性值设置为none时,就可以实现鼠标隐藏效果,语法为“元素{cursor:none}”。

css怎么实现英文小写转为大写css怎么实现英文小写转为大写Apr 25, 2022 pm 06:35 PM

转换方法:1、给英文元素添加“text-transform: uppercase;”样式,可将所有的英文字母都变成大写;2、给英文元素添加“text-transform:capitalize;”样式,可将英文文本中每个单词的首字母变为大写。

vue的keep-alive组件如何优化图片加载体验vue的keep-alive组件如何优化图片加载体验Jul 22, 2023 am 08:09 AM

Vue是一种流行的JavaScript框架,可以帮助我们构建交互式的Web应用程序。在开发过程中,我们常常遇到需要加载大量图片的情况,而这往往会导致页面加载速度变慢,影响用户体验。本文将介绍如何利用Vue的keep-alive组件来优化图片的加载体验。为什么需要优化图片加载体验?图片在网页中扮演着非常重要的角色,可以增加网页的吸引力和可读性,提升用户体验。然

rtl在css是什么意思rtl在css是什么意思Apr 24, 2022 am 11:07 AM

在css中,rtl是“right-to-left”的缩写,是从右往左的意思,指的是内联内容从右往左依次排布,是direction属性的一个属性值;该属性规定了文本的方向和书写方向,语法为“元素{direction:rtl}”。

css怎么设置i不是斜体css怎么设置i不是斜体Apr 20, 2022 am 10:36 AM

在css中,可以利用“font-style”属性设置i元素不是斜体样式,该属性用于指定文本的字体样式,当属性值设置为“normal”时,会显示元素的标准字体样式,语法为“i元素{font-style:normal}”。

See all articles

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

뜨거운 도구

mPDF

mPDF

mPDF는 UTF-8로 인코딩된 HTML에서 PDF 파일을 생성할 수 있는 PHP 라이브러리입니다. 원저자인 Ian Back은 자신의 웹 사이트에서 "즉시" PDF 파일을 출력하고 다양한 언어를 처리하기 위해 mPDF를 작성했습니다. HTML2FPDF와 같은 원본 스크립트보다 유니코드 글꼴을 사용할 때 속도가 느리고 더 큰 파일을 생성하지만 CSS 스타일 등을 지원하고 많은 개선 사항이 있습니다. RTL(아랍어, 히브리어), CJK(중국어, 일본어, 한국어)를 포함한 거의 모든 언어를 지원합니다. 중첩된 블록 수준 요소(예: P, DIV)를 지원합니다.

SublimeText3 영어 버전

SublimeText3 영어 버전

권장 사항: Win 버전, 코드 프롬프트 지원!

Dreamweaver Mac版

Dreamweaver Mac版

시각적 웹 개발 도구

Atom Editor Mac 버전 다운로드

Atom Editor Mac 버전 다운로드

가장 인기 있는 오픈 소스 편집기

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경