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. lintcode:数字三角形

    题目: 数字三角形 给定一个数字三角形,找到从顶部到底部的最小路径和.每一步可以移动到下面一行的相邻数字上. 样例 比如,给出下列数字三角形: [      [2],     [3,4],    [6 ...

  2. JavaWeb项目开发案例精粹-第2章投票系统-004action层

    1. package com.sanqing.action; import java.util.UUID; import com.opensymphony.xwork2.ActionSupport; ...

  3. Ado.Net小练习03(省市联动)

    前台界面:          后台代码: namespace _04省市联动 {     public partial class Form1 : Form     {         public ...

  4. ubuntu下显卡管理

    1 Ubuntu下卸载ATI显卡驱动并还原开源驱动[转] 首先卸载已经安装的ATI显卡驱动:cd /usr/share/ati/sudo ./fglrx-uninstall.sh 接着执行下面的代码: ...

  5. NSDate & NSDateFormatter

    #import <Foundation/Foundation.h>   int main(int argc, const char * argv[]) {    @autoreleasep ...

  6. C++ STL之set的基本操作

    set是集合,虽然也存在键值和实值,不过两者根本就是同一个值,键值的设置完全就是为了满足红黑树的底层结构,set操作与map很像不过也有些不同. 1. set迭代器与map的不同: (1)set使用接 ...

  7. 面试题_76_to_81_Java 最佳实践的面试问题

    包含 Java 中各个部分的最佳实践,如集合,字符串,IO,多线程,错误和异常处理,设计模式等等. 76)Java 中,编写多线程程序的时候你会遵循哪些最佳实践?(答案)这是我在写Java 并发程序的 ...

  8. ha_innobase::rnd_next

    /*****************************************************************//** Reads the next row in a table ...

  9. 永久的CheckBox(单选,全选/反选)!

    <html> <head> <title>选择</title> <script type="text/javascript" ...

  10. POJ 3084 Panic Room (最小割建模)

    [题意]理解了半天--大意就是,有一些房间,初始时某些房间之间有一些门,并且这些门是打开的,也就是可以来回走动的,但是这些门是确切属于某个房间的,也就是说如果要锁门,则只有在那个房间里才能锁. 现在一 ...