<body> <button>加载图片</button> <img src="test.png" alt="测试" data-original = "test2.png"> <script> var oBtn = document.getElementsByTagName('button')[0]; var oImg = document.images[0]; //延迟加载,给图片加了 载入事件 function aftLoadImg(obj, url){ var oImg = new Image(); oImg.onload = function(){ obj.src = oImg.src; } oImg.src = url; } oBtn.onclick = function(){ oImg.src = "test2.png"; // 若是图片不是很大,就直接改一下src就能够了, for (var pro in oImg.dataset) { //这里证实,dataset里面有一个orignial属性,是test2.png。 document.write(pro + " " +oImg.dataset[pro] + "</br>"); //会打印出 original test2.png } //若是以为图片有点大,就直接加载一个事件,上面已经说明过,图像是有onload事件的,等加载完毕后在显示。 if(oImg.dataset){ //是否能够获取dataset属性。 aftLoadImg(oImg, oImg.dataset.original); } else{ aftLoadImg(oImg,oImg.getAttribute("data-original")); } } </script> </body>
<script src="jquery.js" type="text/javascript"></script> <script src="jquery.lazyload.js" type="text/javascript"></script>
b. 须要懒加载的图片, ①.增长 data-original="图片真实地址"javascript
②.页面全部的img标签的src属性指向同一个图片(图片未加载时,显示的一张临时图)css
③.图片必定要设置 width 与 height html
注意:这点你可能没办法接受,由于须要改变你的htmljava
<img src="img/grey.gif" data-original="img/example.jpg" width="640" height="480">
$("img.lazy").lazyload();
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Document</title> <style> body{ margin: 0; width: 500px; } ul{ margin: 0; padding: 0; list-style: none; display: block; } img{ border: none; vertical-align: middle; } .in{ border: 1px solid black; margin: 10px; text-align: center; height: 400px; width: 400px; float: left; } .in img{ height: 400px; width: 400px; } </style> </head> <body> <ul class="list"> <li class="in"><img src="img/loading.gif" alt="测试" data-original = "img/1.png"></li> <li class="in"><img src="img/loading.gif" alt="测试" data-original = "img/2.png"></li> <li class="in"><img src="img/loading.gif" alt="测试" data-original = "img/3.png"></li> <li class="in"><img src="img/loading.gif" alt="测试" data-original = "img/4.png"></li> <li class="in"><img src="img/loading.gif" alt="测试" data-original = "img/1.png"></li> <li class="in"><img src="img/loading.gif" alt="测试" data-original = "img/2.png"></li> <li class="in"><img src="img/loading.gif" alt="测试" data-original = "img/3.png"></li> <li class="in"><img src="img/loading.gif" alt="测试" data-original = "img/4.png"></li> <li class="in"><img src="img/loading.gif" alt="测试" data-original = "img/1.png"></li> <li class="in"><img src="img/loading.gif" alt="测试" data-original = "img/2.png"></li> <li class="in"><img src="img/loading.gif" alt="测试" data-original = "img/3.png"></li> <li class="in"><img src="img/loading.gif" alt="测试" data-original = "img/4.png"></li> <li class="in"><img src="img/loading.gif" alt="测试" data-original = "img/1.png"></li> <li class="in"><img src="img/loading.gif" alt="测试" data-original = "img/2.png"></li> <li class="in"><img src="img/loading.gif" alt="测试" data-original = "img/3.png"></li> <li class="in"><img src="img/loading.gif" alt="测试" data-original = "img/4.png"></li> <li class="in"><img src="img/loading.gif" alt="测试" data-original = "img/1.png"></li> <li class="in"><img src="img/loading.gif" alt="测试" data-original = "img/2.png"></li> <li class="in"><img src="img/loading.gif" alt="测试" data-original = "img/3.png"></li> <li class="in"><img src="img/loading.gif" alt="测试" data-original = "img/4.png"></li> <li class="in"><img src="img/loading.gif" alt="测试" data-original = "img/1.png"></li> <li class="in"><img src="img/loading.gif" alt="测试" data-original = "img/2.png"></li> <li class="in"><img src="img/loading.gif" alt="测试" data-original = "img/3.png"></li> <li class="in"><img src="img/loading.gif" alt="测试" data-original = "img/4.png"></li> </ul> <script> var aImages = document.images; alert(aImages.length); loadImg(aImages); window.onscroll = function(){ loadImg(aImages); }; function loadImg(arr) { for ( var i = 0,len = arr.length; i < len; i++) { // 分别表明该元素上、左、右、下四条边界相对于浏览器窗口左上角(注意,不是文档区域的左上角)的偏移像素值 if (arr[i].getBoundingClientRect().top < document.documentElement.clientHeight && !arr[i].isLoad) { arr[i].isLoad = true; arr[i].style.cssText = "transition: ''; opacity: 0;"; if (arr[i].dataset) { aftLoadImg(arr[i], arr[i].dataset.original); } else { aftLoadImg(arr[i], arr[i].getAttribute("data-original")); } (function(i){ setTimeout(function(){ arr[i].style.cssText = "transition: 1s; opacity: 1;" //transition CSS3渐变 }, 16); })(i); } } } function aftLoadImg(obj, url){ var oImg = new Image(); oImg.onload = function() { obj.src = oImg.src; } oImg.src = url; } </script> </body> </html>
function getH(obj) { var h = 0; while (obj) { h += obj.offsetTop; obj = obj.offsetParent; } return h; }
//当网页的滚动条滚动时要时时判断当前li的位置!jquery
window.onscroll = function () { var oDiv = document.getElementById('listID'); var oUl = oDiv.children[0]; var aLi = oUl.children; for (var i = 0, l = aLi.length; i < l; i++) { var oLi = aLi[i]; //检查oLi是否在可视区域 var t = document.documentElement.clientHeight + (document.documentElement.scrollTop || document.body.scrollTop); var h = getH(oLi); if (h < t) { setTimeout("setImg(" + i + ")", 500); } } };
//当页面加载完成之后要主动运行一下window.onscroll,从而得到当前可视范围内的图片。浏览器
window.onload = function () { window.onscroll(); };