動(dòng)機(jī) 原生JavaScript已經(jīng)對(duì) Image 對(duì)象提供了 onload 和 onerror 注冊(cè)事件。但在瀏覽器緩存及其他因素的影響下,用戶在使用 " /> 性饥渴姓交HDSEX,超碰在线视频97,xxxx美国老师1819

天天躁日日躁狠狠躁AV麻豆-天天躁人人躁人人躁狂躁-天天澡夜夜澡人人澡-天天影视香色欲综合网-国产成人女人在线视频观看-国产成人女人视频在线观看

Track Image Loading效果代碼分析

目的
在圖片的加載過程中,提供定義圖片加載成功或加載失敗/超時(shí)時(shí)的回調(diào)函數(shù),并確保執(zhí)行。 

動(dòng)機(jī)
原生JavaScript已經(jīng)對(duì) Image 對(duì)象提供了 onload 和 onerror 注冊(cè)事件。但在瀏覽器緩存及其他因素的影響下,用戶在使用回退按鈕或者刷新頁面時(shí) onload 事件常常未能穩(wěn)定觸發(fā)。在我開發(fā)的相冊(cè)系統(tǒng)中,我希望圖片能根據(jù)自定義的大小顯示以免導(dǎo)致頁面變形,例如最寬不得超過500px,而小于500px寬度的圖片則按原大小顯示。CSS2 提供了 max-width 屬性能夠幫組我們實(shí)現(xiàn)這一目的。但很遺憾,挨千刀的IE6并不支持。 


IE6一個(gè)彌補(bǔ)的辦法就是通過注冊(cè) img.onload 事件,待圖片加載完成后自動(dòng)調(diào)整大小。以下代碼取自著名的Discuz!論壇系統(tǒng)4.1版本對(duì)顯示圖片的處理。 


<img src="http://img8.imagepile.NET/img8/47104p155.jpg" border="0"
onload="if(this.width>screen.width*0.7) {this.resized=true; this.width=screen.width*0.7; 
this.alt='Click here to open new windownCTRL+Mouse wheel to zoom in/out';}" 
onmouseover="if(this.width>screen.width*0.7) {this.resized=true; this.width=screen.width*0.7; this.style.cursor='hand'; this.alt='Click here to open new windownCTRL+Mouse wheel to zoom in/out';}" 
onclick="if(!this.resized) {return true;} else {window.open('http://img8.imagepile.NET/img8/47104p155.jpg');}" 
onmousewheel="return imgzoom(this);">

前文已述,瀏覽器并不保證事件處理函數(shù)執(zhí)行。所以需要一個(gè)更穩(wěn)定的方式跟蹤圖片加載過程,并執(zhí)行設(shè)定的回調(diào)函數(shù)。 

實(shí)現(xiàn)
image.complete 屬性標(biāo)示的是圖片加載狀態(tài),其值如果為ture,則表示加載成功。圖片不存在或加載超時(shí)則值為false。利用 setInterval() 函數(shù)定時(shí)檢查該狀態(tài)則可以實(shí)現(xiàn)跟蹤圖片加載的狀況。代碼片斷如下: 



ImageLoader = Class.create();
ImageLoader.prototype = {
  initialize : function(options) {
    this.options = Object.extend({
      timeout: 60, //60s
      onInit: Prototype.emptyFunction,
      onLoad: Prototype.emptyFunction,
      onError: Prototype.emptyFunction
    }, options || {});
    this.images = [];
    this.pe = new PeriodicalExecuter(this._load.bind(this), 0.02);
  },
       ........
}

利用Prototype 的PeriodicalExecuter類創(chuàng)建一個(gè)定時(shí)器,每隔20毫秒檢查一次圖片的加載情況,并根據(jù)狀態(tài)執(zhí)行 options 參數(shù)中定義的回調(diào)函數(shù)。 

使用



var loader = new ImageLoader({
  timeout: 30,
  onInit: function(img) {
    img.style.width = '100px';
  },
  onLoad: function(img) {
    img.style.width = '';
    if (img.width > 500) 
      img.style.width = '500px';
  },
  onError: function(img) {
    img.src = 'error.jpg'; //hint image
  }
});loader.loadImage(document.getElementsByTagName('img'));

上面的代碼定義圖片最初以100px顯示,加載成功后如果圖片實(shí)際寬度超過500px,則再強(qiáng)制定義為500px,否則顯示原大小。如果圖片不存在或加載超時(shí)(30秒為超時(shí)),則顯示錯(cuò)誤圖片。 

同理,可以應(yīng)用 ImageLoader 的回調(diào)函數(shù)來根據(jù)需求自定義效果,例如默認(rèn)顯示loading,加載完成后再顯示原圖;圖片首先灰度顯示,加載完成后再恢復(fù)亮度等等。例如: 



//need scriptaculous effects.js
var loader = new ImageLoader({
  onInit: function(img) {
    Element.setOpacity(img, 0.5); //默認(rèn)5級(jí)透明
  },
  onLoad: function(img) {
    Effect.Appear(img);  //恢復(fù)原圖顯示
  }
});


附示例中包含完整的代碼及使用pconline圖片為例的測(cè)試, 注意 范例中使用了最新的Prototype 1.5.0_rc1。

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 //EN">
<html>
<head>
<script src="prototype1.5.0_rc1.js"></script>
<script src="validation1.5.3/effects.js"></script>
</head>

<body>
<img id="img0" src="http://img.pconline.com.cn/images/photoblog/2026024/20069/14/1158169144171.jpg" />

<img id="img1" src="http://img.pconline.com.cn/images/photoblog/2026024/20069/14/1158169158366.jpg" />

<img id="img2" src="http://img.pconline.com.cn/images/photoblog/2026024/20069/14/1158169169983_mthumb.jpg" />

<br />加載失敗測(cè)試<br />
<img id="img2" src="http://img.pconline.com.cn/images/photoblog/2026024/20069/14/000000000000.jpg" />


<script type="text/Javascript">
ImageLoader = Class.create();
ImageLoader.prototype = {

  initialize : function(options) {
    this.options = Object.extend({
      timeout: 60, //60s
      onInit: Prototype.emptyFunction,
      onLoad: Prototype.emptyFunction,
      onError: Prototype.emptyFunction
    }, options || {});
    this.images = [];
    this.pe = new PeriodicalExecuter(this._load.bind(this), 0.02);
  },

  loadImage : function() {
    var self = this;
    $A(arguments).each(function(img) {
      if (typeof(img) == 'object')
        $A(img).each(self._addImage.bind(self));
      else
        self._addImage(img);
    });
  },

  _addImage : function(img) {
    img = $(img);
    img.onerror = this._onerror.bind(this, img);
    this.options.onInit.call(this, img);
    if (this.options.timeout > 0) {
      setTimeout(this._ontimeout.bind(this, img), this.options.timeout*1000);
    }
    this.images.push(img);
    if (!this.pe.timer)
      this.pe.registerCallback();
  },

    
  _load: function() {
    this.images = this.images.select(this._onload.bind(this));
    if (this.images.length == 0) {
      this.pe.stop();
    }
  },

  _checkComplete : function(img) {
    if (img._error) {
      return true;
    } else {
      return img.complete;
    }
  },

  _onload : function(img) {
    if (this._checkComplete(img)) {
      this.options.onLoad.call(this, img);
      img.onerror = null;
      if (img._error)
        try {delete img._error}catch(e){}
      return false;
    }
    return true;
  },

  _onerror : function(img) {
    img._error = true;
    img.onerror = null;
    this.options.onError.call(this, img);
  },

  _ontimeout : function(img) {
    if (!this._checkComplete(img)) {
      this._onerror(img);
    }
  }

}

var loader = new ImageLoader({
  timeout: 30,
  onInit: function(img) {
    img.style.width = '100px';
  },
  onLoad: function(img) {
    img.style.width = '';
    if (img.width > 500) { 
      img.style.width = '500px';
    }
  },
  onError: function(img) {
    img.src = 'http://img.pconline.com.cn/nopic.gif';
  }
});

loader.loadImage(document.getElementsByTagName('img'));

/*
var loader = new ImageLoader({
  timeout: 30,
  onInit: function(img) {
    Element.setOpacity(img, 0.5);
  },
  onLoad: function(img) {
    Effect.Appear(img);
  },
  onError: function(img) {
    img.src = 'http://img.pconline.com.cn/nopic.gif';
  }
});
*/

/*
$A(document.getElementsByTagName('img')).each(
function(img) {
  img.onload = function() {
    img.style.width = '300px';
  }
}
);
*/

</script>
</body>
</html>

JavaScript技術(shù)Track Image Loading效果代碼分析,轉(zhuǎn)載需保留來源!

鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標(biāo)記有誤,請(qǐng)第一時(shí)間聯(lián)系我們修改或刪除,多謝。

主站蜘蛛池模板: 青草在线观看视频 | 亚洲第一色网 | 免费99精品国产人妻自在线 | 国产成人精品精品欧美 | 国产成人啪精品视频免费网 | 午夜理论片日本中文在线 | 在教室伦流澡到高潮H女攻视频 | 亚洲精品在线播放视频 | 亚洲精品影院久久久久久 | 少妇伦子伦精品无码 | 动漫美女脱小内内露尿口 | 天天插天天射天天干 | 久久黄色精品视频 | 日日碰狠狠躁久久躁77777 | 东日韩二三区 | 人人射人人爱 | 久章草一区二区 | 国产精品人妻一区免费看8C0M | 中文字幕在线观看国产 | 99久久国产综合精品成人影院 | 日本日本熟妇中文在线视频 | 日产国产欧美韩国在线 | 男人插女人动态 | 久久精品嫩草影院免费看 | 九九热视频 这里有精品 | 日本午夜精品久久久无码 | 国产午夜高潮熟女精品AV | 欧美 亚洲 日韩 在线综合 | 亚洲AV蜜桃永久无码精品无码网 | 久久大香萑太香蕉av | 午夜理论电影在线观看亚洲 | 东莞桑拿美女 | 日本午夜精品理论片A级APP发布 | 国产成人精品视频免费大全 | 成人在线精品视频 | 中文字幕AV在线一二三区 | 9亚洲欧洲免费无码在线 | 爽死你个放荡粗暴小淫货漫画 | 精品国产国偷自产在线观看 | 老阿姨才是最有V味的直播 牢记永久免费网址 | 自拍黄色片 |