原生js實現(xiàn)瀑布流布局
更新時間:2017年03月08日 10:01:59 作者:Vampire-blog
這篇文章主要為大家詳細介紹了原生js實現(xiàn)瀑布流布局的相關(guān)資料,具有一定的參考價值,感興趣的小伙伴們可以參考一下
用js實現(xiàn)瀑布流布局以及通過模擬的數(shù)據(jù)加載圖片,已標記注釋
效果如圖:
<!DOCTYPE html> <html> <head lang="en"> <meta charset="UTF-8"> <title>瀑布流布局-JS實現(xiàn)</title> </head> <style type="text/css"> *{ margin: 0; padding: 0; } #main{ position: relative;/*整體相對定位,因為每個小圖片盒子的位置是通過計算再由絕對定位放置,是需要相對于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ù)塊渲染到當前頁面底部 for(var i=0;i<dataInt.data.length;i++){//dataInt對象的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;//計算每個box的寬度 //計算整個頁面顯示的列數(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);//將第一行的各個高度加到數(shù)組中 }else{ var minH=Math.min.apply(null,hArr);//apply方法可以改變數(shù)組的指向,因為Math.min方法不支持數(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; } } } //檢測是否具備了滾動條加載數(shù)據(jù)塊的條件 function checkscrollSlide(){ //最后一個盒子的距頂部的高度加上自身高度的一半 var lastBoxH=oBoxs[oBoxs.length-1].offsetTop+ Math.floor(oBoxs[oBoxs.length-1].offsetHeight/2); //頁面滾走的距離 var scrollTop=document.body.scrollTop||document.documentElement.scrollTop; //當前瀏覽器窗口可視區(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)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
精通Javascript系列之Javascript基礎(chǔ)篇
javascrpit的基本概念分析,剛開始學(xué)習(xí)js的朋友可以參考下。2011-06-06functional繼承模式 摘自javascript:the good parts
javascript:the good parts 書中Inheritance部分講到了一種functional的繼承方式, 具體這個functional該如何翻譯,就不是很清楚了, 就直接意會一下吧2011-06-06nuxt+axios實現(xiàn)打包后動態(tài)修改請求地址的方法
這篇文章主要介紹了nuxt+axios實現(xiàn)打包后動態(tài)修改請求地址的方法,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-04-04JS中不應(yīng)該使用箭頭函數(shù)的四種情況詳解
箭頭函數(shù)給我們的工作帶來了極大的方便,但是它們有什么缺點呢?我們應(yīng)該一直使用箭頭函數(shù)嗎?我們應(yīng)該在哪些場景中停止使用箭頭函數(shù)?本文就來為大家詳細講講2022-07-07詳解小程序開發(fā)經(jīng)驗:多頁面數(shù)據(jù)同步
這篇文章主要介紹了小程序開發(fā)經(jīng)驗:多頁面數(shù)據(jù)同步,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-05-05