利用CSS、JavaScript及Ajax实现图片预加载的三大方法及优缺点分析

预加载图片是提高用户体验的一个很好方法。图片预先加载到浏览器中,访问者便可顺利地在你的网站上冲浪,并享受到极快的加载速度。这对图片画廊及图片占据很大比例的网站来说十分有利,它保证了图片快速、无缝地发布,也可帮助用户在浏览你网站内容时获得更好的用户体验。本文将分享三个不同的预加载技术,来增强网站的性能与可用性。

方法一:用CSS和JavaScript实现预加载
实现预加载图片有很多方法,包括使用CSS、JavaScript及两者的各种组合。这些技术可根据不同设计场景设计出相应的解决方案,十分高效。
单纯使用CSS,可容易、高效地预加载图片,代码如下:

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

将这三个ID选择器应用到(X)HTML元素中,我们便可通过CSS的background属性将图片预加载到屏幕外的背景上。只要这些图片的路径保持不变,当它们在Web页面的其他地方被调用时,浏览器就会在渲染过程中使用预加载(缓存)的图片。简单、高效,不需要任何JavaScript。
该方法虽然高效,但仍有改进余地。使用该法加载的图片会同页面的其他内容一起加载,增加了页面的整体加载时间。为了解决这个问题,我们增加了一些JavaScript代码,来推迟预加载的时间,直到页面加载完毕。代码如下:

// better image preloading @ <A href="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/</A> 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 (typeof window.onload != 'function') {    window.onload = func;    } else {    window.onload = function() {    if (oldonload) {    oldonload();    }    func();    }    }    
}    
addLoadEvent(preloader);  
View Code

在该脚本的第一部分,我们获取使用类选择器的元素,并为其设置了background属性,以预加载不同的图片。
该脚本的第二部分,我们使用addLoadEvent()函数来延迟preloader()函数的加载时间,直到页面加载完毕。
如果JavaScript无法在用户的浏览器中正常运行,会发生什么?很简单,图片不会被预加载,当页面调用图片时,正常显示即可。
方法二:仅使用JavaScript实现预加载
上述方法有时确实很高效,但我们逐渐发现它在实际实现过程中会耗费太多时间。相反,我更喜欢使用纯JavaScript来实现图片的预加载。下面将提供两种这样的预加载方法,它们可以很漂亮地工作于所有现代浏览器之上。
JavaScript代码段1
只需简单编辑、加载所需要图片的路径与名称即可,很容易实现:

<div class="hidden">    <script type="text/javascript">    <!--//--><![CDATA[//><!--             var images = new Array()    function preload() {    for (i = 0; i < preload.arguments.length; i++) {    images[i] = new Image()    images[i].src = preload.arguments[i]    }    }    preload(    "http://domain.tld/gallery/image-001.jpg",    "http://domain.tld/gallery/image-002.jpg",    "http://domain.tld/gallery/image-003.jpg"  )    //--><!]]>     </script>    
</div>  
View Code

该方法尤其适用预加载大量的图片。我的画廊网站使用该技术,预加载图片数量达50多张。将该脚本应用到登录页面,只要用户输入登录帐号,大部分画廊图片将被预加载。
JavaScript代码段2
该方法与上面的方法类似,也可以预加载任意数量的图片。将下面的脚本添加入任何Web页中,根据程序指令进行编辑即可。

<div class="hidden"> <script type="text/javascript"> <!--//--><![CDATA[//><!--             if (document.images) { img1 = new Image(); img2 = new Image(); 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"; } //--><!]]>     </script> 
</div>
View Code

正如所看见,每加载一个图片都需要创建一个变量,如“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);  
View Code

方法三:使用Ajax实现预加载

上面所给出的方法似乎不够酷,那现在来看一个使用Ajax实现图片预加载的方法。该方法利用DOM,不仅仅预加载图片,还会预加载CSS、JavaScript等相关的东西。使用Ajax,比直接使用JavaScript,优越之处在于JavaScript和CSS的加载不会影响到当前页面。该方法简洁、高效。

window.onload = function() {    setTimeout(function() {    // XHR to request a JS and a CSS         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('');    // preload image         new Image().src = "http://domain.tld/preload.png";    }, 1000);    
};  
View Code

上面代码预加载了“preload.js”、“preload.css”和“preload.png”。1000毫秒的超时是为了防止脚本挂起,而导致正常页面出现功能问题。
下面,我们看看如何用JavaScript来实现该加载过程:

window.onload = function() {    setTimeout(function() {    // reference to <head>           var head = document.getElementsByTagName('head')[0];    // a new CSS            var css = document.createElement('link');    css.type = "text/css";    css.rel  = "stylesheet";    css.href = "http://domain.tld/preload.css";    // a new JS            var js  = document.createElement("script");    js.type = "text/javascript";    js.src  = "http://domain.tld/preload.js";    // preload JS and CSS         head.appendChild(css);    
        head.appendChild(js);    // preload image            new Image().src = "http://domain.tld/preload.png";    }, 1000);    };  
View Code

这里,我们通过DOM创建三个元素来实现三个文件的预加载。正如上面提到的那样,使用Ajax,加载文件不会应用到加载页面上。从这点上看,Ajax方法优越于JavaScript。 

转载于:https://www.cnblogs.com/ranzige/p/js_pic_preload.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/421366.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

html表格

<html><head><title>easy</title></head><body><!--超链接--><a href"http://www.baidu.com" target"_self">百度</a><!--在当前页面打开百度--><a href"http://www.baidu.com"…

jquery中邮箱地址 URL网站地址正则验证实例代码

jquery中邮箱地址 URL网站地址正则验证实例代码 QQ网站有一个网站举报的功能&#xff0c;看了一些js代码觉得写得很不错&#xff0c;我就拿下来了&#xff0c;下面是一个email验证与url网址验证js代码&#xff0c;分享给大家 email地址验证 复制代码代码如下:function checkEma…

html鼠标悬停位置,html – 当我将鼠标悬停在其上时,我想隐藏图像并在其位置显示文本...

不确定我是否理解你想要的东西,但这对你有用吗&#xff1f;初始案例#wrapper {position: relative;}.text {opacity: 0;position: absolute;bottom: 0;}.hover:hover {opacity: 0;}.hover:hover .text {opacity: 1;}text​扩展案例#wrapper {display: inline-block;position: …

Java多线程、线程池及线程同步(synchronized关键字、悲观锁、乐观锁)

1.进程与线程定义 进程包含线程&#xff0c;如一个百度网盘进程&#xff0c;该进程的线程可以有上传&#xff0c;下载。 2.创建线程的三种方式 方式1-继承Thread类 方式2-实现Runnabled接口 1.常规写法 2.匿名内部类写法 方式3-实现Callable接口 示例代码&#xff1a; f1.get…

html表单总结

<html><head><title>表单总结</title></head><body background"C:\Users\Pictures\web\cute1.jpg"><form action"C.html" method"post" target"_self">Name:<input type"text"…

怎么批量修改html文件后缀,怎么批量修改文件后缀

问题是这样的&#xff0c;有一个web项目&#xff0c;其中包含很多以html为后缀的文件(分别在不同目录下)&#xff0c;如今想把他们的后缀改为 jsp&#xff0c;如果手工改的确比较累人&#xff0c;我比较喜欢偷懒&#xff0c;于是写个小程序帮我干&#xff0c;这样以后遇到此类问…

Analysis of Cloud Computing Architectures阅读笔记--提出了Screen虚拟化方法

作者&#xff1a;Ritika Mittal, Kritika Soni 单位&#xff1a;来自印度的一个私立学校,Manav Rachna International University 文章大意&#xff1a; 分析了云计算的一些基本知识&#xff0c;分析了CloneCloud&#xff0c;它认为CloneCloud的缺点在于处理延迟上&#xff0c;…

html聚光灯特效,css实现聚光灯效果的代码分享

简介CSS Variables&#xff0c;一个并不是那么新的东西&#xff0c;但对css来说绝对是一场革命。之前使用变量的时候&#xff0c;需要借助sass、less等预处理工具来实现&#xff0c;现在我们可以直接使用css来声明变量。兼容性老规矩&#xff0c;先来看下兼容性兼容性一片绿&am…

a/a的4种链接方式

1.<a href"#" target"_self"></a>自己的页面跳到要打开的页面。 2.<a href"#" target"_blank"></a>打开一个新的页面。 3.<a href"#" target"_top"></a>部分覆盖自己的页面。…

字符串转16进制字节数组,字节数组转16进制字符串

/// <summary>/// 字符串转16进制字节数组/// </summary>/// <param name"hexString"></param>/// <returns></returns>public static byte[] Str_ToHexByte(string hexString){hexString hexString.Replace(" ", &q…

二本大学计算机专业国际认证,计算机专业二本大学排名

技校网专门为您推荐的类似问题答案问题1&#xff1a;理科计算机强的二本大学排名杭州电子科技大学 南京邮电大学 重庆邮电大学 桂林电子科技大学 重庆理工大学 成都理工大学 武汉科技大学 长沙理工大学 黑龙江大学问题2&#xff1a;二本院校计算机专业排名二本学校自然排名没出…

css的常用选择器

1&#xff0c;标签选择器(在段落里) <style>p{color:pink;font-size:49px;font-family:"宋体";text-decoration:none; } </style><body><p>helloworld</p> </body>2.类名选择器 <style>.a{color:pink;font-size:49px;font…

dw替换多个html标签,DW查找替换的技巧

在开发建设网站的过程中&#xff0c;也许我们会遇到这样的情况&#xff0c;当我们的网站已经进行了相当部分&#xff0c;但是发现还需要对某些细节进行修改。这时候不可能完全的依靠手工去更改了&#xff0c;怎么办呢&#xff1f;利用Dreamwaver中查找替换也许能够帮助实现这些…

100重构过程

如果现有代码类繁多&#xff0c;不符合唯一职责&#xff0c;一开始分析代码结构就没意义了。1.看做过程化代码阅读&#xff0c;分析出代码做了几件事。2.针对代码做的事补充单元测试。3.设计新的代码结构4分析新老结构差异&#xff0c;制定重构步骤&#xff0c;把原代码一点点演…

div

1.div与table的区别: 都是一样的表格,容器效果,但用div进行页面设计更灵活,可以任意调节大小和移动. 2.它是块标签,会自占一行,而行标签就不会自占一行,如 3.div的移动(浮动) float:left; float:right; 1,浮动可以理解为一个div进入了一个新的空间,但下一个div会挤到上个div的空…

面试计算机应用技术自我介绍,计算机应用专业面试的自我介绍

计算机应用专业面试的自我介绍我叫**是**财经职业学院的一名信息管理系计算机及应用专业的应届毕业生。三年的专业课和相关的辅修课学习&#xff0c;让我在计算机领域内有了比较扎实的理论基础。通过在学校机房和个人电脑的不断练习&#xff0c;并能比较系统地把所学的知识用到…

基于visual Studio2013解决面试题之0203栈实现

&#xfeff;&#xfeff;&#xfeff;题目解决代码及点评/*用模板类实现栈*//* 标准输入输出流头文件 */ #include <iostream> /* 将标准库的std命名空间下标示符提升到全局 */ using namespace std;/* 定义栈模板库 */ template <class T> class stack { public:…

div盒子模型

<!DOCTYPE html> <html><head><meta charset"UTF-8"><title></title><style type"text/css">#box{width: 400px;height: 400px;border: 5px pink dotted;/*边框的以圆点组成的虚线*/padding-left: 150px;paddin…

html地图缩放比例,百度地图之添加控件——比例尺、缩略图、平移缩放

地图控件概述百度地图上负责与地图交互的UI元素称为控件。百度地图API中提供了丰富的控件&#xff0c;您还能够经过Control类来实现自定义控件。javascript地图API中提供的控件有&#xff1a;cssControl&#xff1a;控件的抽象基类&#xff0c;全部控件均继承此类的方法、属性。…