国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

jQuery簡單實現圖片預加載

2019-11-20 12:37:58
字體:
來源:轉載
供稿:網友

jQuery實現圖片預加載

JS代碼

$(function(){   loadImg("http://d.hiphotos.baidu.com/image/pic/item/fd039245d688d43f14f69eff7f1ed21b0ef43b5b.jpg",addImg);  function loadImg(url,callback){    var img = new Image();    img.onload = function(){      img.onload = null;      callback(img);    }    img.src=url;    img.width ="202";    img.height = "202";    img.attr("defaulturl","../images/img.png");    if(){}  }  function addImg(img){    $(img).appendTo($(".imgload li"))  }})

HTML:

<!doctype html><html lang="en"><head>  <meta charset="UTF-8">  <title>圖片預加載</title>  <link rel="stylesheet" type="text/css" href="css/index.css">  <script type="text/javascript" src="js/jquery-1.8.3.min.js"></script>  <script type="text/javascript" src="js/index.js"></script></head><body>       <div class="imgload">      <ul>          <li class="fl"></li>          <li class="fl"></li>          <li class="fl"></li>          <li class="fl"></li>          <li class="fl"></li>          <li class="fl"></li>          <li class="fl"></li>          <li class="fl"></li>          <li class="fl"></li>      </ul>    </div></body></html>

其他實例

function loadimg(arr,funLoading,funOnLoad,funOnError){   var numLoaded=0,   numError=0,   isObject=Object.prototype.toString.call(arr)==="[object Object]" ? true : false;     var arr=isObject ? arr.get() : arr;   for(a in arr){     var src=isObject ? $(arr[a]).attr("data-src") : arr[a];     preload(src,arr[a]);   }     function preload(src,obj){     var img=new Image();     img.onload=function(){       numLoaded++;       funLoading && funLoading(numLoaded,arr.length,src,obj);       funOnLoad && numLoaded==arr.length && funOnLoad(numError);     };     img.onerror=function(){       numLoaded++;       numError++;       funOnError && funOnError(numLoaded,arr.length,src,obj);     }     img.src=src;   }   } 

參數說明:
  arr:可以是存放圖片路徑的一個數組,也可以是選取到的img的jquery對象;
  funLoading:每一個單獨的圖片加載完成后執行的操作;
  funOnLoad:全部圖片都加載完成后的操作;
  funOnError:單個圖片加載出錯時的操作。

懶加載,

var imgonload=function(errors){     /*errors:加載出錯的圖片數量;*/   console.log("loaded,"+errors+" images loaded error!"); }   var funloading=function(n,total,src,obj){     /*     n:已加載完成的數量;     total:總共需加載的圖片數量;     src:當前加載完成的圖片路徑;     obj:當loadimg函數中傳入的arr為存放圖片路徑的數組時,obj=src,是圖片路徑,         當arr為jquery對象時,obj是當前加載完成的img dom對象。     */   console.log(n+"of"+total+" pic loaded.",src);   var newimg = document.createElement("img");   newimg.src=src;   $("body").append(newimg).fadeIn(); }   var funloading_obj=function(n,total,src,obj){   console.log(n+"of"+total+" pic loaded.",src);   $(obj).attr("src",src);   $(obj).fadeIn(200); }   var funOnError=function(n,total,src,obj){   console.log("the "+n+"st img loaded Error!"); } 

調試用例

console.log("loading..."); loadimg($("img"),funloading_obj,imgonload,funOnError); /*loadimg(["http://pic22.nipic.com/20120619/9607634_212642465144_2.jpg",      "http://pic21.nipic.com/20120531/1670912_103610084349_2.jpg",      "http://pic21.nipic.com/20120616/4952071_130629530136_2.jpg",      "http://pic21.nipic.com/20120610/1723580_105037029000_2.jpg",      "http://pic22.nipic.com/20120617/2572038_125013326121_2.jpg"     ],funloading,imgonload,funOnError);*/ 

以上所述就是本文的全部內容了,希望大家能夠喜歡。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 锦州市| 长垣县| 宿松县| 乐平市| 连云港市| 麦盖提县| 昌邑市| 巴彦淖尔市| 临清市| 博客| 饶阳县| 苍山县| 苗栗县| 阿巴嘎旗| 丹东市| 禄丰县| 旺苍县| 沐川县| 抚远县| 克拉玛依市| 东莞市| 东阳市| 洪湖市| 临夏县| 九龙坡区| 启东市| 紫阳县| 博爱县| 遵义县| 东宁县| 济宁市| 鄯善县| 淅川县| 宣城市| 社旗县| 宁阳县| 化德县| 迁安市| 牟定县| 正镶白旗| 武隆县|