您好,登錄后才能下訂單哦!
這篇“JavaScriptL如何實現(xiàn)瀑布流布局”文章的知識點大部分人都不太理解,所以小編給大家總結(jié)了以下內(nèi)容,內(nèi)容詳細(xì),步驟清晰,具有一定的借鑒價值,希望大家閱讀完這篇文章能有所收獲,下面我們一起來看看這篇“JavaScriptL如何實現(xiàn)瀑布流布局”文章吧。
一、經(jīng)典套路:JavaScript+絕對定位
HTML結(jié)構(gòu):
<divid="main">
...<divclass="box">
<divclass="wrapper">
<divclass="pic"><imgsrc=""/></div>
<divclass="text">簡單介紹</div>
</div>
</div>
...</div>
整個瀑布流區(qū)域用一個<divid="main">作為父容器
瀑布流中的每個數(shù)據(jù)塊用.box作為基本布局,.wrapper呈現(xiàn)樣式和實際內(nèi)容
CSS樣式:
*{margin:0;padding:0;}html,body{width:100%;height:100%;background-color:#EDEDED;}#main{
position:relative;
width:1280px;/*限定父容器的寬度*/
margin:0auto;
}.box{
position:absolute;
padding:7px;/*不建議使用margin*/
box-sizing:border-box;
width:256px;/*限定數(shù)據(jù)塊的寬度*/}.wrapper{
padding:5px;
background-color:#fff;
border:1pxsolid#e4e4e4;
box-shadow:01px5pxrgba(0,0,0,.2);
}.pic{
font-size:0;/*消除行內(nèi)元素的間隙*/}.picimg{
width:100%;
height:auto;
}.text{
color:#999;
background:#FAFAFA;
font-size:14px;
padding-top:5px;
}
在.box中設(shè)置了padding是為了留出視覺上的間距
之所以不使用margin,是因為后面會使用js獲取元素的offsetWidth和offsetHeight
而這兩個屬性值是不計算margin的
JavaScript:
window.onload=function(){
waterFall('main','box')
}
functionwaterFall(main,box){varmain=document.getElementById(main);varboxs=main.getElementsByClassName(box);varboxWidth=boxs[0].offsetWidth;//獲取每個數(shù)據(jù)塊的寬度
varmainWidh=main.offsetWidth;//獲取主容器的寬度
varcols=Math.floor(mainWidh/boxWidth);//計算列數(shù)
varheightArr=[];//定義一個存放top值的數(shù)組
for(vari=0;i<boxs.length;i++){varboxHeight=boxs[i].offsetHeight;if(i<cols){//第一行heightArr.push(boxs[i].offsetHeight);
boxs[i].style.top='0px';
boxs[i].style.left=i*boxWidth+'px';
}else{//求出最矮盒子的高度
varminBoxHeight=Math.min.apply(this,heightArr);
//求出最矮盒子的索引
varminBoxIndex=getIndex(minBoxHeight,heightArr);
boxs[i].style.top=minBoxHeight+'px';//頂部間距即最矮盒子的高度
boxs[i].style.left=minBoxIndex*boxWidth+'px';
//關(guān)鍵:更新最矮盒子的高度
heightArr[minBoxIndex]+=boxHeight;
}
}
}
functiongetIndex(val,arr){for(variinarr){if(val==arr[i]){returni;
}
}
}
這種方案一開始給.box設(shè)置了position:absolute;
所以在打開頁面的時候,如果頁面性能較差,可能會出現(xiàn)所有數(shù)據(jù)塊堆疊在一起的情況
可以將.box的position:absolute替換為float:left,然后在js添加定位樣式的時候,再補上position:absolute,視覺上會有所改觀
二、純CSS3實現(xiàn)瀑布流
CSS3中新增了一個屬性column,可以通過規(guī)定列數(shù)column-count,讓瀏覽器自適應(yīng)布局
只需要刪除上面的JavaScript部分,然后修改#main和.box:
#main{
width:1280px;
margin:0auto;
-webkit-column-count:5;
column-count:5;
-webkit-column-gap:0;
column-gap:0;
}.box{
padding:7px;
box-sizing:border-box;
width:256px;
}
但通過這種方式實現(xiàn)的瀑布流,實際上是按照縱向排列的,而之前的經(jīng)典方案是按照橫向排列的
作為一個CSS3的新屬性,只有IE10及以上的瀏覽器才支持column
以上就是關(guān)于“JavaScriptL如何實現(xiàn)瀑布流布局”這篇文章的內(nèi)容,相信大家都有了一定的了解,希望小編分享的內(nèi)容對大家有幫助,若想了解更多相關(guān)的知識內(nèi)容,請關(guān)注億速云行業(yè)資訊頻道。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。