圖片懶加載

圖片懶加載,javascript

  思路:當鼠標滑動到對應圖片的高度時,進行圖片的加載;css

  

<!DOCTYPE html>
<html>
	<head>
		<meta charset="UTF-8">
		<title></title>
		<style type="text/css">
			#div{
				width: 575px;
				height: auto;
                overflow: hidden;
                border: red 1px solid;
                margin: 0 auto;
                /*給該div設置定位*/
                position: relative;
			}
			#div img{
				width: 267px;
				height: 396px;
				margin-left: 10px;
				border: 1px solid #000;
			}
		</style>
		<script type="text/javascript">
			function getPos(obj){
				var l = 0;
				var t = 0;
				while(obj){
					
					l += obj.offsetLeft;
					t += obj.offsetTop;
					obj = obj.offsetParent;
				}
				return {left:l ,top : t}
			}
			window.onload = window.onscroll =  function(){
				//獲取到img
				    var aImg = document.getElementsByTagName("img");
				//獲取到它的scrollTop 值   考慮兼容問題
					var oScrollTop = document.documentElement.scrollTop || document.body.scrollTop;
//				 clientHeight = 上下padding + height
					var clientH = document.documentElement.clientHeight;
					//循環遍歷每一項經過調用獲取到每個i 項對象的top 值
					for (var i = 0;i<aImg.length;i++) {
						var aImgTop = getPos(aImg[i]).top;
//						當滾動的時候進行判斷,看他的滾動的高度加上它的clientHeight  是否比它的 top 值大   
//						若是大或等於說明滾動到當前位置能夠加載圖片
						if (oScrollTop + clientH >= aImgTop) {
//							進行圖片的加載
							aImg[i].src = aImg[i].getAttribute("_src");
						}
					}
			}
		</script>
	</head>
	<body>
		<div id="div">
			<img _src="../img/1.jpg"/>
			<img _src="../img/2.jpg"/>
			<img _src="../img/3.jpg"/>
			<img _src="../img/4.jpg"/>
			<img _src="../img/6.jpg"/>
			<img _src="../img/7.jpg"/>
			<img _src="../img/1.jpg"/>
			<img _src="../img/2.jpg"/>
			<img _src="../img/3.jpg"/>
			<img _src="../img/4.jpg"/>
			<img _src="../img/6.jpg"/>
			<img _src="../img/7.jpg"/>
			<img _src="../img/3.jpg"/>
			<img _src="../img/4.jpg"/>
			<img _src="../img/6.jpg"/>
			<img _src="../img/7.jpg"/>
		</div>
	</body>
</html>

  當有相似於瀑布流的佈局時經常使用的 加載模式html

相關文章
相關標籤/搜索