原生js實現(xiàn)瀑布流效果
本文實例為大家分享了js實現(xiàn)瀑布流效果的具體代碼,供大家參考,具體內(nèi)容如下
CSS樣式:
<style> .cont{margin: 0 auto;position: relative;} .box{float: left;padding: 5px;} .imgbox{border: black solid 1px;padding: 5px;border-radius: 5px;} .imgbox img{width: 200px;display: block;} </style>
HTML結(jié)構(gòu):
<div class="cont"> <div class="box"> <div class="imgbox"> <img src="img/1.jpg" > </div> </div> //......此處省略雷同代碼 <div class="box"> <div class="imgbox"> <img src="img/2.jpg" > </div> </div> </div>
JavaScript代碼:
<script> onload = function(){ var wf = new WaterF(); wf.init(); } class WaterF{ constructor(){ this.clientW = document.documentElement.clientWidth; this.abox = document.querySelectorAll(".box"); this.cont = document.querySelector(".cont"); } init(){ this.maxNum = parseInt(this.clientW / this.abox[0].offsetWidth); this.cont.style.width = this.maxNum * this.abox[0].offsetWidth + "px"; this.firstLine(); this.otherLine(); } firstLine(){ this.heightArr = []; for(var i=0;i<this.maxNum;i++){ this.heightArr.push(this.abox[i].offsetHeight); } } otherLine(){ for(var i=this.maxNum;i<this.abox.length;i++){ var min = Math.min(...this.heightArr); var minIndex = this.heightArr.indexOf(min); this.abox[i].style.position = "absolute"; this.abox[i].style.top = min + "px"; this.abox[i].style.left = minIndex * this.abox[0].offsetWidth + "px"; this.heightArr[minIndex] = this.heightArr[minIndex] + this.abox[i].offsetHeight; } } } </script>
小編還為大家準(zhǔn)備了精彩的專題:瀑布流布局匯總
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
詳解template標(biāo)簽用法(含vue中的用法總結(jié))
這篇文章主要介紹了template標(biāo)簽用法(含vue中的用法總結(jié)),本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友參考下吧2021-01-01JS 對象(Object)和字符串(String)互轉(zhuǎn)方法
下面小編就為大家?guī)硪黄狫S 對象(Object)和字符串(String)互轉(zhuǎn)方法。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2016-05-05微信端調(diào)取相冊和攝像頭功能,實現(xiàn)圖片上傳,并上傳到服務(wù)器
這篇文章主要介紹了微信端調(diào)取相冊和攝像頭功能圖片上傳服務(wù)器,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-05-05詳解JS如何使用Promise緩存網(wǎng)絡(luò)請求
網(wǎng)絡(luò)請求是現(xiàn)代Web應(yīng)用中的常見操作,很多時候需要獲取服務(wù)器上的數(shù)據(jù),在進行網(wǎng)絡(luò)請求時,為了減輕服務(wù)器的壓力,緩存策略常被用來避免對同一數(shù)據(jù)的重復(fù)請求,本文將探討如何使用Promise結(jié)合緩存來高效處理網(wǎng)絡(luò)請求,需要的朋友可以參考下2023-12-12JavaScript this在函數(shù)中的指向及實例詳解
這篇文章主要介紹了JavaScript this在函數(shù)中的指向及實例詳解,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下2019-10-10JS庫particles.js創(chuàng)建超炫背景粒子插件(附源碼下載)
particles.js用于創(chuàng)建粒子的輕量級 JavaScript 庫。使用方法非常簡單,代碼也很容易實現(xiàn),下面通過本文給大家分享JS庫particles.js創(chuàng)建超炫背景粒子插件附源碼下載,需要的朋友參考下吧2017-09-09用javascript修復(fù)瀏覽器中頭痛問題的方法整理篇[譯]
我們提倡無論何時都盡可能地使用CSS,這樣我們更容易取得成功.現(xiàn)在瀏覽器對CSS的支持已經(jīng)非常好,肯定足以讓你用來控制你的網(wǎng)頁布局與排版.但,即使如此,還是有某些頁面元素會在不同的瀏覽器下表現(xiàn)也不一樣.2008-11-11