data:image/s3,"s3://crabby-images/91ad7/91ad7981d102cb7f69665ff6c77e674a2b61d4cd" alt=""
data:image/s3,"s3://crabby-images/b9b05/b9b052c9addd9a205fd8ce00e4b9d0547d86f1f9" alt=""
data:image/s3,"s3://crabby-images/9ae35/9ae35fa71abfa323d0f5d3c077dcede400365ee1" alt=""
data:image/s3,"s3://crabby-images/a0cef/a0cef1ac1b570a0f7a4b7262fb37afa1e1d239f2" alt=""
data:image/s3,"s3://crabby-images/38cac/38cacc93a336b95777cd79c7450d3b8cb65b0274" alt=""
data:image/s3,"s3://crabby-images/48a99/48a99ae958dbc049a7e505fac6f6ab5c9b0a696b" alt=""
data:image/s3,"s3://crabby-images/33ed6/33ed608ad3eabe526bee11541d95a5940ea88cc5" alt=""
data:image/s3,"s3://crabby-images/204c1/204c1fe19d849785a00a0a444e9c899737a7ca0f" alt=""
data:image/s3,"s3://crabby-images/84a7f/84a7f6f81f5b2c54142b4a24291093546e4ad7b1" alt=""
data:image/s3,"s3://crabby-images/43860/43860b8e0d808ba9ab55296478eec48bebf8eb12" alt=""
data:image/s3,"s3://crabby-images/201b8/201b806fd85ea1947c14372952d44f07c4da05db" alt=""
data:image/s3,"s3://crabby-images/ad5b3/ad5b3b2dee001669e5933d1618d43f57f9adf61c" alt=""
data:image/s3,"s3://crabby-images/e70cc/e70cc782d3f22c5bcb8d90ed4a6650e9b898fde0" alt=""
data:image/s3,"s3://crabby-images/38660/3866072e2ea9165c48f4489d33c691bc3d4393a0" alt=""
data:image/s3,"s3://crabby-images/bd38e/bd38ec4d7b8140cd7d867fb70a6e09722a098c79" alt=""
data:image/s3,"s3://crabby-images/0e656/0e656c3617be2f6ce0d7b77dd233277d8d20a782" alt=""
data:image/s3,"s3://crabby-images/29745/2974597d513a881f1632d54e8cd60558b95bbb9b" alt=""
data:image/s3,"s3://crabby-images/e8770/e8770c2d361fdf3fc81ee314c1e7c44943f4e258" alt=""
data:image/s3,"s3://crabby-images/99eab/99eabfe0364fd024e3c2a4f66f589f66467bce3a" alt=""
data:image/s3,"s3://crabby-images/a0782/a07826acf27de63eecc20cdba48405e77b9170b3" alt=""
data:image/s3,"s3://crabby-images/e8d06/e8d060c7a9be57961eadf71f38b78568ac464b8b" alt=""
data:image/s3,"s3://crabby-images/085c9/085c9cb1266a5e99edcc76223b1ae9e4c44d4cea" alt=""
data:image/s3,"s3://crabby-images/babb7/babb7fae0e7dc832dfb1e2972bb6122289af0bec" alt=""
data:image/s3,"s3://crabby-images/08047/08047cdaa0ed2aeeda8ec8de31a387ac898219e1" alt=""
data:image/s3,"s3://crabby-images/64db8/64db87c3c81e10a39b382bd00fcb50757d7011d9" alt=""
data:image/s3,"s3://crabby-images/f7fd1/f7fd105039a09def73f31b4637387e7dfb098f97" alt=""
如何实现瀑布流布局?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。
index.html
waterfall layout ![]()
![]()
![]()
![]()
![]()
![]()
![]()
![]()
![]()
![]()
![]()
![]()
![]()
![]()
![]()
![]()
![]()
![]()
![]()
![]()
![]()
![]()
![]()
![]()
![]()
![]()
wf.css
@CHARSET "UTF-8"; *{margin:0;padding:0} #main{ position: relative; margin: 10px auto 0 auto; } .box{ float:left; padding: 0 0 15px 15px; } .pic{ border: 1px solid #ccc; padding: 10px; } .box img{ width: 200px; height: auto; }
wf.js
window.onload = function(){ waterfall(); //要加载的数据,暂时写一个固定数据 var dataInt = {"data":[{"src":'3.jpg'},{"src":'13.jpg'},{"src":'23.jpg'},{"src":'1.jpg'}]}; //一个判断拖动滚动条后是否加载新内容的方法 window.onscroll = function(){ if(checkScrollSlide()){ //将数据块渲染到当前页的尾部 for(var i = 0; i < dataInt.data.length;i++){ var parent = document.getElementById('main'); var newBox = document.createElement('p'); newBox.className = 'box'; parent.appendChild(newBox); var newPic = document.createElement('p'); newPic.className = 'pic'; newBox.appendChild(newPic); var newImg = document.createElement('img'); newImg.src = "./imgs/" + dataInt.data[i].src; newPic.appendChild(newImg); waterfall(); } } } } function waterfall(){ var parent = document.getElementById("main"); //写一个方法根据类名box,找到所有节点 var boxArr = getByClass(parent,'box'); //console.log(boxArr.length);//26,检验是否获取到 var bodyWidth = document.body.clientWidth; //document.body.clientWidth 窗口实时显示时的body的宽度 var colWidth = boxArr[0].offsetWidth;//box p的宽度 var cols = Math.floor(bodyWidth / colWidth); //给main p一个宽度,从而让显示内容不会随着浮动,改变布局 var mainWidth = colWidth * cols; parent.style.cssText = 'width:' + mainWidth + 'px;'; var colsHeight = [];//放列高度的数组 for(var i = 0; i < boxArr.length;i++){ var iBox = boxArr[i]; if(i < cols){ colsHeight.push(iBox.offsetHeight); }else{ var rArr = searchMin(colsHeight); var index = rArr[0]; var minH = rArr[1]; var left = parseInt(index * colWidth); var top = minH; iBox.style.position = "absolute"; iBox.style.left = left + 'px'; iBox.style.top = top + 'px'; colsHeight[index] += iBox.offsetHeight; } } } function getByClass(parent,clsName){ //用通配符获得prent下的所有标签节点 var allTags = document.getElementsByTagName("*"); var arr = new Array(); for(var i = 0; i < allTags.length;i++){ if(allTags[i].className == clsName){ arr.push(allTags[i]); } } return arr; } function searchMin(arr){ var min = arr[0]; var index = 0; for(var j = 0; j < arr.length; j++){ if(arr[j] < min){ min = arr[j]; index = j; } } return [index,min]; } function checkScrollSlide(){ var parent = document.getElementById('main'); var boxArr = getByClass(parent,'box'); var lastBox = boxArr[boxArr.length-1]; var lbHeight = lastBox.offsetTop+Math.floor(lastBox.offsetHeight/2); console.log(lbHeight); var slideH = document.body.scrollTop || document.documentElement.scrollTop; console.log(slideH); var winH = document.body.clientHeight || document.documentElement.clientHeight; console.log(winH); var swHeight = slideH + winH; return (lbHeight < swHeight) ? true : false; }
关于如何实现瀑布流布局问题的解答就分享到这里了,希望以上内容可以对大家有一定的帮助,如果你还有很多疑惑没有解开,可以关注创新互联网站制作公司行业资讯频道了解更多相关知识。