記錄JS實現瀑布流照片牆效果javascript
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>瀑布流</title> <link rel="stylesheet" type="text/css" href="js瀑布流.css"> <script type="text/javascript" src="js瀑布流.js"></script> </head> <body> <div id="container"> <div class="box"> <div class="box_img"> <img src="img/1.jpg"/> </div> </div> <div class="box"> <div class="box_img"> <img src="img/2.jpg"/> </div> </div> <div class="box"> <div class="box_img"> <img src="img/3.jpg"/> </div> </div> <div class="box"> <div class="box_img"> <img src="img/4.jpg"/> </div> </div> <div class="box"> <div class="box_img"> <img src="img/5.jpg"/> </div> </div> <div class="box"> <div class="box_img"> <img src="img/6.jpg"/> </div> </div> <div class="box"> <div class="box_img"> <img src="img/7.jpg"/> </div> </div> <div class="box"> <div class="box_img"> <img src="img/8.jpg"/> </div> </div> <div class="box"> <div class="box_img"> <img src="img/9.jpg"/> </div> </div> <div class="box"> <div class="box_img"> <img src="img/10.jpg"/> </div> </div> <div class="box"> <div class="box_img"> <img src="img/11.jpg"/> </div> </div> </div> </body> </html>
*{ margin:0px; padding: 0px; } #container{ position: relative; } .box{ padding: 5px; float: left; } .box_img{ padding: 5px; border: 1px solid #cccccc; box-shadow: 0 0 5px #cccccc; border-radius: 5px; } .box_img img{ width: 150px; height: auto; }
function imgLocation(parent,content){ var cparent=document.getElementById(parent); var cconten=getChildElement(cparent,content);//獲得全部子節點 var imgWidth=cconten[0].offsetWidth// 獲得寬度,每張圖片的寬度都是固定的,因此這裏能夠隨便取一張 var cols=Math.floor(document.documentElement.clientWidth/imgWidth)//頻幕的寬度除以圖片的寬度,就是這一排能放圖片的個數 cparent.style.cssText="width:"+imgWidth*cols+"px; margin:0 auto"; //設置主容器的樣式 var boxHeightArr=[];//第一排圖片的高度 for(var i=0;i<cconten.length;i++){ if (i<cols) { //若是是第一排 ,cols爲一排能放圖片的個數 boxHeightArr[i]=cconten[i].offsetHeight; } else{ //找到第一排最小圖片的高度 var minHeight=Math.min.apply(null,boxHeightArr)//最小圖片的高度 var minIndex= getminHeightLocation(boxHeightArr,minHeight); cconten[i].style.position="absolute"; cconten[i].style.top=minHeight+"px"; cconten[i].style.left=cconten[minIndex].offsetLeft+"px"; boxHeightArr[minIndex]=boxHeightArr[minIndex]+cconten[i].offsetHeight;//把當前最小的高度加上當前追加圖片的高度 } } }
function getChildElement(parent,content){ var contentArr=[]; var allContent=parent.getElementsByTagName("*"); for (var i = 0; i <allContent.length; i++){ if(allContent[i].className==content){ contentArr.push(allContent[i]) } } return contentArr; }
function getminHeightLocation(boxHeightArr,minHeight) { for(var i in boxHeightArr){ if(boxHeightArr[i]==minHeight){ return i; } } }
function checkFlag(){ var cparent=document.getElementById("container"); var cconten=getChildElement(cparent,"box"); var lastContentHeight=cconten[cconten.length-1].offsetTop; //最後一張圖片距頂部的高度 var scrollTop=document.documentElement.scrollTop||document.body.scrollTop;//當前滾動距頂部的高度 var pageHeight=document.documentElement.clientHeight||document.body.clientHeight;//當前頁面的高度 if(lastContentHeight<scrollTop+pageHeight){ return true; } }
window.onload=function(){ imgLocation("container","box") var imgData={'data':[{'src':'92.jpg'},{'src':'16.jpg'},{'src':'17.jpg'},{'src':'18.jpg'}]}; //鼠標滾動事件 window.onscroll=function(){ if(checkFlag()){ //是否須要加載圖片 var cparent=document.getElementById("container"); for(var i=0;i<imgData.data.length;i++){ var cconten=document.createElement("div"); cconten.className="box"; cparent.appendChild(cconten); var boximg=document.createElement("div"); boximg.className="box_img"; cconten.appendChild(boximg); var img=document.createElement("img"); img.src="img/"+imgData.data[i].src; boximg.appendChild(img); } imgLocation("container","box") } } }