1,脚本代码:

 /**
  * 图片头数据加载就绪事件 - 更快获取图片尺寸
  * @version    2011.05.27
  * @author    TangBin
  * @see        http://www.planeart.cn/?p=1121
  * @param    {String}    图片路径
  * @param    {Function}    尺寸就绪
  * @param    {Function}    加载完毕 (可选)
  * @param    {Function}    加载错误 (可选)
  * @example imgReady('http://www.google.com.hk/intl/zh-CN/images/logo_cn.png', function () {
         alert('size ready: width=' + this.width + '; height=' + this.height);
     });
  */
 var imgReady = (function () {
     var list = [], intervalId = null,

     // 用来执行队列
     tick = function () {
         var i = 0;
         for (; i < list.length; i++) {
             list[i].end ? list.splice(i--, 1) : list[i]();
         };
         !list.length && stop();
     },

     // 停止所有定时器队列
     stop = function () {
         clearInterval(intervalId);
         intervalId = null;
     };

     return function (url, ready, load, error) {
         var onready, width, height, newWidth, newHeight,
             img = new Image();

         img.src = url;

         // 如果图片被缓存,则直接返回缓存数据
         if (img.complete) {
             ready.call(img);
             load && load.call(img);
             return;
         };

         width = img.width;
         height = img.height;

         // 加载错误后的事件
         img.onerror = function () {
             error && error.call(img);
             onready.end = true;
             img = img.onload = img.onerror = null;
         };

         // 图片尺寸就绪
         onready = function () {
             newWidth = img.width;
             newHeight = img.height;
             if (newWidth !== width || newHeight !== height ||
                 // 如果图片已经在其他地方加载可使用面积检测
                 newWidth * newHeight > 1024
             ) {
                 ready.call(img);
                 onready.end = true;
             };
         };
         onready();

         // 完全加载完毕的事件
         img.onload = function () {
             // onload在定时器时间差范围内可能比onready快
             // 这里进行检查并保证onready优先执行
             !onready.end && onready();

             load && load.call(img);

             // IE gif动画会循环执行onload,置空onload即可
             img = img.onload = img.onerror = null;
         };

         // 加入队列中定期执行
         if (!onready.end) {
             list.push(onready);
             // 无论何时只允许出现一个定时器,减少浏览器性能损耗
             if (intervalId === null) intervalId = setInterval(tick, 40);
         };
     };
 })();

2,调用方式:

2     alert('size ready: width=' this.width + '; height=' this.height);
3 });

(通过测试的浏览器:Chrome、Firefox、Safari、Opera、IE6、IE7、IE8)

原文链接:http://www.planeart.cn/?p=1121

【转】javascript-图片预加载技术的更多相关文章

  1. 再谈javascript图片预加载技术

    图片预加载技术的典型应用: 如lightbox方式展现照片,无疑需要提前获得大图的尺寸,这样才能居中定位,由于javascript无法获取img文件头数据,必须等待其加载完毕后才能获取真实的大小然后展 ...

  2. Javascript图片预加载详解

    预加载图片是提高用户体验的一个很好方法.图片预先加载到浏览器中,访问者便可顺利地在你的网站上冲浪,并享受到极快的加载速度.这对图片画廊及图片占据很大比例的网站来说十分有利,它保证了图片快速.无缝地发布 ...

  3. Javascript图片预加载详解 分类: JavaScript HTML+CSS 2015-05-29 11:01 768人阅读 评论(0) 收藏

    预加载图片是提高用户体验的一个很好方法.图片预先加载到浏览器中,访问者便可顺利地在你的网站上冲浪,并享受到极快的加载速度.这对图片画廊及图片占据很大比例的网站来说十分有利,它保证了图片快速.无缝地发布 ...

  4. javascript图片预加载

    图片预加载是非常常见的一个功能,PC和移动端都会用到,尤其是在移动端,只要涉及到较多图片的加载都会用到该技术.下面是移动端用到的,引入了zepto. <!DOCTYPE html> < ...

  5. javascript 图片预加载

    <!DOCTYPE > <html xmlns="http://www.w3.org/1999/xhtml"> <head> <meta ...

  6. 转载:用Jquery实现的图片预加载技术,可以实现有序加载和无序加载!

    一.背景 我们在做页面的时候,从用户体验的角度出发,肯定是希望用户以最快的速度看到完整的页面信息,但在实际情况中经常会遇到些问题. 比如受网速影响,页面加载素材的时间比较长,页面会出现短时间的错乱或者 ...

  7. 用es6类封装的图片预加载技术!

    1.HTML <!DOCTYPE html> <html lang="en"> <head> <meta charset="UT ...

  8. JQ封装图片预加载插件

    我们知道,图片的加载,特别是资源较大的图片,加载相当耗费时间.为了提高用户体验,不得不使用图片预加载技术来提前加载,以提高用户在浏览时的流畅度. 先来弄明白图片的懒加载和预加载的不同: 1)概念:懒加 ...

  9. 利用CSS、JavaScript及Ajax实现图片预加载的三大方法

    预加载图片是提高用户体验的一个很好方法.图片预先加载到浏览器中,访问者便可顺利地在你的网站上冲浪,并享受到极快的加载速度.这对图片画廊及图片占据很大比例的网站来说十分有利,它保证了图片快速.无缝地发布 ...

  10. javascript图片懒加载与预加载的分析

    javascript图片懒加载与预加载的分析 懒加载与预加载的基本概念.  懒加载也叫延迟加载:前一篇文章有介绍:JS图片延迟加载 延迟加载图片或符合某些条件时才加载某些图片. 预加载:提前加载图片, ...

随机推荐

  1. sqlserver防止数据库挂马新尝试

    想法不错,放着以后应该会有用 网站挂马非常让人头痛,每次的安全措施都是治标不治本,想找到根本原因,只能去分析你的程序源代码,由于很多网站不是一个程序员开发,很多的注入漏洞很难发现,曾经通过公共文件加入 ...

  2. linux shell 命令学习(1) du- estimate file space usage

    du - estimate file space usage , 计算文件的磁盘大小 语法格式: du [OPTION] ... [FILE] 描述: 汇总每个文件的磁盘大小, 递归汇总目录的大小, ...

  3. iOS xcuserdata

    说明:       project.xcworkspace说明:is a directory of files describing the workspace or projects. Althou ...

  4. 利用PhantomJS搭建Highcharts export服务

    利用PhantomJS搭建Highcharts export服务 一直在使用Highcharts做web图表的展示, 但是当发送定时的报表邮件的遇到了这个问题. 为了保证邮件图表和web页图表样式一致 ...

  5. distinct用法

    distinct可以列出不重复的记录,对于单个字段来说distinct使用比较简单,但是对于多个字段来说,distinct使用起来会使人发狂.而且貌似也没有见到微软对distinct使用多字段的任何说 ...

  6. hdu 3433 A Task Process(dp+二分)

    题目链接 题意:n个人, 要完成a个x任务, b个y任务. 求,最短的时间 思路:由于时间较大,用 二分来找时间. dp[i][j]表示 i个人完成j个x任务, 最多能完成的y任务个数 这个题 不是很 ...

  7. JAVA操作数据库插入中文表中显示乱码的解决方法

    String dbUrl = "jdbc:mysql://localhost:3306/BookDB?useUnicode=true&characterEncoding=GB2312 ...

  8. HDU 2586 + HDU 4912 最近公共祖先

    先给个LCA模板 HDU 1330(LCA模板) #include <cstdio> #include <cstring> #define N 40005 struct Edg ...

  9. BootStrap图标

  10. bzoj2395

    分组赛时学到的最小乘积生成树模型,感觉这个思路非常神,可以说是数形结合的经典问题 由于生成树有两个权值,我们把每个生成树的权值表示成点坐标(sa,sb) 显然我们知道,乘积最小,那么点必然落在下凸壳上 ...