原生js實(shí)現(xiàn)瀑布流布局
用js實(shí)現(xiàn)瀑布流布局以及通過模擬的數(shù)據(jù)加載圖片,已標(biāo)記注釋
效果如圖:

<!DOCTYPE html>
<html>
<head lang="en">
<meta charset="UTF-8">
<title>瀑布流布局-JS實(shí)現(xiàn)</title>
</head>
<style type="text/css">
*{
margin: 0;
padding: 0;
}
#main{
position: relative;/*整體相對(duì)定位,因?yàn)槊總€(gè)小圖片盒子的位置是通過計(jì)算再由絕對(duì)定位放置,是需要相對(duì)于main盒子*/
}
.box{
padding: 15px 0 0 15px;/*padding為內(nèi)邊距,后面js獲取的高度包括padding的距離*/
float: left;
}
.pic{
padding: 10px;
border: 1px solid #ccc;
border-radius: 5px;
box-shadow: 0 0 5px #ccc;
}
.pic img{
width: 165px;
height: auto;
}
</style>
<script type="text/javascript">
window.onload=function(){
var oParent=document.getElementById("main");
var oBoxs=oParent.getElementsByClassName("box");
waterfall('main','box');//調(diào)用瀑布布局的函數(shù)
var dataInt={"data":[{"src":'23.jpg'},{"src":'24.jpg'},{"src":'25.jpg'}]}//模擬出要加載的圖片
window.onscroll=function(){
if(checkscrollSlide()){//如果調(diào)用函數(shù)的返回結(jié)果為true
//將數(shù)據(jù)塊渲染到當(dāng)前頁面底部
for(var i=0;i<dataInt.data.length;i++){//dataInt對(duì)象的data屬性的長度
var oBox=document.createElement('div');
oBox.className='box';
oParent.appendChild(oBox);//添加到父元素的最后
var oPic=document.createElement('div');
oPic.className='pic';
oBox.appendChild(oPic);
var oImg=document.createElement('img');
oImg.src="img/"+dataInt.data[i].src;
oPic.appendChild(oImg);
}
waterfall('main','box');
};
}
function waterfall(parent,box){
var oParent=document.getElementById(parent);
var oBoxs=oParent.getElementsByClassName(box);
var oBoxW=oBoxs[0].offsetWidth;//計(jì)算每個(gè)box的寬度
//計(jì)算整個(gè)頁面顯示的列數(shù)(頁面寬/box的寬)
var cols=Math.floor(document.documentElement.clientWidth/oBoxW);
//設(shè)置main的寬,居中
oParent.style.cssText='width:'+oBoxW*cols+'px;margin:0 auto;';
var hArr=[];//存放每一列高度的數(shù)組
for(var i=0;i<oBoxs.length;i++){
if(i<cols){
hArr.push(oBoxs[i].offsetHeight);//將第一行的各個(gè)高度加到數(shù)組中
}else{
var minH=Math.min.apply(null,hArr);//apply方法可以改變數(shù)組的指向,因?yàn)镸ath.min方法不支持?jǐn)?shù)組
var index=getMinhIndex(hArr,minH);
oBoxs[i].style.position='absolute';
oBoxs[i].style.top=minH+'px';
oBoxs[i].style.left=oBoxs[index].offsetLeft+'px';
hArr[index]+=oBoxs[i].offsetHeight;
}
}
}
function getMinhIndex(arr,val){
for(var i in arr){
if(arr[i]==val){
return i;
}
}
}
//檢測(cè)是否具備了滾動(dòng)條加載數(shù)據(jù)塊的條件
function checkscrollSlide(){
//最后一個(gè)盒子的距頂部的高度加上自身高度的一半
var lastBoxH=oBoxs[oBoxs.length-1].offsetTop+ Math.floor(oBoxs[oBoxs.length-1].offsetHeight/2);
//頁面滾走的距離
var scrollTop=document.body.scrollTop||document.documentElement.scrollTop;
//當(dāng)前瀏覽器窗口可視區(qū)域高度
var height=document.body.clientHeight||document.documentElement.clientHeight;
return (lastBoxH<scrollTop+height) ? true : false;
}
}
</script>
<body>
<div id="main">
<div class="box">
<div class="pic">
<img src="img/0.jpg" />
</div>
</div>
<div class="box">
<div class="pic">
<img src="img/1.jpg" />
</div>
</div>
<div class="box">
<div class="pic">
<img src="img/2.jpg" />
</div>
</div>
<div class="box">
<div class="pic">
<img src="img/3.jpg" />
</div>
</div>
<div class="box">
<div class="pic">
<img src="img/4.jpg" />
</div>
</div>
<div class="box">
<div class="pic">
<img src="img/5.jpg" />
</div>
</div>
<div class="box">
<div class="pic">
<img src="img/6.jpg" />
</div>
</div>
<div class="box">
<div class="pic">
<img src="img/7.jpg" />
</div>
</div>
<div class="box">
<div class="pic">
<img src="img/8.jpg" />
</div>
</div>
<div class="box">
<div class="pic">
<img src="img/9.jpg" />
</div>
</div>
<div class="box">
<div class="pic">
<img src="img/10.jpg" />
</div>
</div>
<div class="box">
<div class="pic">
<img src="img/11.jpg" />
</div>
</div>
<div class="box">
<div class="pic">
<img src="img/12.jpg" />
</div>
</div>
<div class="box">
<div class="pic">
<img src="img/13.jpg" />
</div>
</div>
<div class="box">
<div class="pic">
<img src="img/14.jpg" />
</div>
</div>
<div class="box">
<div class="pic">
<img src="img/15.jpg" />
</div>
</div>
<div class="box">
<div class="pic">
<img src="img/16.jpg" />
</div>
</div>
<div class="box">
<div class="pic">
<img src="img/17.jpg" />
</div>
</div>
<div class="box">
<div class="pic">
<img src="img/18.jpg" />
</div>
</div>
<div class="box">
<div class="pic">
<img src="img/19.jpg" />
</div>
</div>
<div class="box">
<div class="pic">
<img src="img/20.jpg" />
</div>
</div>
<div class="box">
<div class="pic">
<img src="img/21.jpg" />
</div>
</div>
<div class="box">
<div class="pic">
<img src="img/22.jpg" />
</div>
</div>
</div>
</body>
</html>
以上就是本文的全部內(nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- 原生JS實(shí)現(xiàn)響應(yīng)式瀑布流布局
- 解析瀑布流布局:JS+絕對(duì)定位的實(shí)現(xiàn)
- 微信小程序通過js實(shí)現(xiàn)瀑布流布局詳解
- 純js實(shí)現(xiàn)瀑布流布局及ajax動(dòng)態(tài)新增數(shù)據(jù)
- 原生JS實(shí)現(xiàn)美圖瀑布流布局賞析
- JavaScript瀑布流布局實(shí)現(xiàn)代碼
- 詳解javascript實(shí)現(xiàn)瀑布流絕對(duì)式布局
- JS實(shí)現(xiàn)瀑布流布局
- javascript瀑布流布局實(shí)現(xiàn)方法詳解
- js實(shí)現(xiàn)瀑布流布局(無限加載)
相關(guān)文章
微信web端后退強(qiáng)制刷新功能的實(shí)現(xiàn)代碼
這篇文章主要介紹了微信web端后退強(qiáng)制刷新功能的實(shí)現(xiàn)代碼,需要的朋友可以參考下2018-03-03
Javascript排序算法之計(jì)數(shù)排序的實(shí)例
計(jì)數(shù)排序是一種高效的線性排序,它通過計(jì)算一個(gè)集合中元素楚翔的次數(shù)來確定集合如何排列,計(jì)數(shù)排序不需要進(jìn)行數(shù)據(jù)的比較,所有他的運(yùn)行效率前面介紹的都高2014-04-04
JS在TextArea光標(biāo)位置插入文字并實(shí)現(xiàn)移動(dòng)光標(biāo)到文字末尾
JS在TextArea光標(biāo)位置插入文字+移動(dòng)光標(biāo)到文字末尾,F(xiàn)irefox,Chrome,Safari以及Opera都有selectionStart和selectionEnd屬性,具體實(shí)現(xiàn)如下,感興趣的朋友可以參考下哈2013-06-06
Javascript實(shí)現(xiàn)的分頁函數(shù)
Javascript實(shí)現(xiàn)的分頁函數(shù)...2007-02-02
Javascript中引用類型傳遞的知識(shí)點(diǎn)小結(jié)
這篇文章主要給大家介紹了關(guān)于Javascript中引用類型傳遞的知識(shí)點(diǎn),文中介紹的非常詳細(xì),需要的朋友可以參考借鑒,下面來一起看看吧。2017-03-03
js實(shí)現(xiàn)簡單登錄功能的實(shí)例代碼
js驗(yàn)證用戶身份,登錄成功之后等待一定秒數(shù),跳轉(zhuǎn)到操作頁面。使用window函數(shù)。代碼如下2013-11-11

