如何用JS实现网页瀑布流布局
网络编程 2021-07-04 14:07www.168986.cn编程入门
这篇文章主要介绍了如何用JS实现网页瀑布流布局,帮助大家更好的利用JavaScript制作网页,感兴趣的朋友可以了解下
前言
瀑布流 又称瀑布流式布局,是比较流行的一种网站页面布局方式。即多行等宽元素排列,后面的元素依次添加到其后,等宽不等高,根据图片原比例缩放直至宽度达到我们的要求,依次按照规则放入指定位置。
什么是瀑布流布局
先看效果
- 图片多行等宽元素排列,后面的元素依次添加到其后,等宽不等高,根据图片原比例缩放直至宽度达到我们的要求,依次按照规则放入指定位置。
- 为了方便理解,在此先给上html、css代码
不完整html代码
<div id="container"> <div class="box"> <div class="box-img"> <img src="./img/1.jpg" alt=""> </div> </div> <div class="box"> <div class="box-img"> <img src="./img/2.jpg" alt=""> </div> </div> <div class="box"> <div class="box-img"> <img src="./img/3.jpg" alt=""> </div> </div> </div> ......<!-- 省略了图片,多少张图片自行决定-->
完整的css代码
{ padding: 0; margin: 0; } #container{ position: relative; } .box{ float: left; padding: 15px; } .box-img { width: 150px; padding: 5px; border: 1px solid #c ; box-shadow: 0 0 5px #c; border-radius: 5px; } .box-img img{ width: 100%; height: auto; }
如何实现
简单地来说,如果要实现瀑布流布局,得完成这几件事✍
1. 获取图片
function getChildElemnt() { const contentArr = []//定义数组准备装图 const parent = document.getElementById(container)//得到整个页面 const allContent = parent.getElementsByTagName('')//得到整个标签 console.log(allContent); for (var i = 0; i < allContent.length; i++) { if (allContent[i].className == 'box') { contentArr.push(allContent[i])//将class='box'的标签装入数组 } } console.log(contentArr); return contentArr//返回数组 }
2. 设置图片宽带
var ontent = getChildElemnt() var imgWidth = ontent[0].offsetWidth//令所有图片宽度等于第一张图片
3. 计算浏览器页面一行最多能存放图片的数量
var dWidth=document.documentElement.clientWidth//页面宽度 var num = Math.floor(dWidth/ imgWidth) //Math.floor()向下取整
4. 比较图片高度
因为在瀑布流布局中,当第一行图片已经摆满后,第二行的第一张图片要放在第一行中高度最小的图片的狼蚁网站SEO优化
var BoxHeightArr = []//定义一个数组,把每张图片的高度依次放进去 for (var i = 0; i < ontent.length; i++) { if (i < num) { BoxHeightArr[i] = ontent[i].offsetHeight//将图片的高度存入数组 } else {//当第一行已经存放不了图片后 var minHeight = Math.min.apply(null, BoxHeightArr)//比较出上一行最小的高度 } }
5. 得到上一行中最小高度图片的位置
//定义一个getMinHeightLocation函数,给它传入BoxHeightArr上一行全部图片,和minHeight上一行图片的最小高度 function getMinHeightLocation(BoxHeightArr, minHeight) { for (var i in BoxHeightArr) { if (BoxHeightArr[i] === minHeight) {//当图片高度等于最小高度时,该图片的位置为最小高度图片的位置 return i } } }
6. 插图
for (var i = 0; i < ontent.length; i++) { if (i < num) { BoxHeightArr[i] = ontent[i].offsetHeight } else { var minHeight = Math.min.apply(null, BoxHeightArr) var minIndex = getMinHeightLocation(BoxHeightArr, minHeight) ontent[i].style.position = 'absolute'//将要插入的图片绝对定位,即元素的位置通过 "left", "", "right" 以及 "bottom" 属性进行规定 ontent[i].style. = minHeight + 'px'//令插入的图片到顶端的距离刚好等于要插其狼蚁网站SEO优化图片的高度 ontent[i].style.left = ontent[minIndex].offsetLeft + 'px'//令插入的图片到最左边的距离刚好等于要插其狼蚁网站SEO优化图片到最左边的距离 BoxHeightArr[minIndex] = BoxHeightArr[minIndex] + ontent[i].offsetHeight//插入图片后,得将这位置的高度设为两张图片的高度和 } }
完整代码如下
优化代码,提高性能
window.onload = function() { imgLocation('container', 'box')//构造函数imgLocation } //用window.onload = function() {}函数就不用等着body页面中调用就可以执行了 // 获取到当前有多少张图片要摆放 function imgLocation(parent, content) {//令parent='container',content='box' // 将parent下所有的内容全部取出 var cparent = document.getElementById(parent) var ontent = getChildElemnt(cparent, content) var imgWidth = ontent[0].offsetWidth var num = Math.floor(document.documentElement.clientWidth / imgWidth) cparent.style.cssText = `width: ${imgWidth num} px` var BoxHeightArr = [] for (var i = 0; i < ontent.length; i++) { if (i < num) { BoxHeightArr[i] = ontent[i].offsetHeight } else { var minHeight = Math.min.apply(null, BoxHeightArr) var minIndex = getMinHeightLocation(BoxHeightArr, minHeight) ontent[i].style.position = 'absolute' ontent[i].style. = minHeight + 'px' ontent[i].style.left = ontent[minIndex].offsetLeft + 'px' BoxHeightArr[minIndex] = BoxHeightArr[minIndex] + ontent[i].offsetHeight } } // console.log(BoxHeightArr); } function getChildElemnt(parent, content) {parent='container',content='box' const contentArr = [] const allContent = parent.getElementsByTagName('') console.log(allContent); for (var i = 0; i < allContent.length; i++) { if (allContent[i].className == content) { contentArr.push(allContent[i]) } } console.log(contentArr); return contentArr } function getMinHeightLocation(BoxHeightArr, minHeight) { for (var i in BoxHeightArr) { if (BoxHeightArr[i] === minHeight) { return i } } }
以上就是如何用JS实现网页瀑布流布局的详细内容,更多关于JS实现网页瀑布流布局的资料请关注狼蚁SEO其它相关文章!
上一篇:JavaScript 实现页面滚动动画
下一篇:详解JavaScript错误捕获
编程语言
- 如何快速学会编程 如何快速学会ug编程
- 免费学编程的app 推荐12个免费学编程的好网站
- 电脑怎么编程:电脑怎么编程网咯游戏菜单图标
- 如何写代码新手教学 如何写代码新手教学手机
- 基础编程入门教程视频 基础编程入门教程视频华
- 编程演示:编程演示浦丰投针过程
- 乐高编程加盟 乐高积木编程加盟
- 跟我学plc编程 plc编程自学入门视频教程
- ug编程成航林总 ug编程实战视频
- 孩子学编程的好处和坏处
- 初学者学编程该从哪里开始 新手学编程从哪里入
- 慢走丝编程 慢走丝编程难学吗
- 国内十强少儿编程机构 中国少儿编程机构十强有
- 成人计算机速成培训班 成人计算机速成培训班办
- 孩子学编程网上课程哪家好 儿童学编程比较好的
- 代码编程教学入门软件 代码编程教程