瀑布流布局

html 复制代码
<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>瀑布流</title>
</head>

<style>
  * {
    margin: 0;
    padding: 0;
  }

  #container {
    position: relative;
  }

  .box {
    float: left;
    width: 350px;
    padding: 5px;
  }

  img {
    width: 100%;
  }
</style>

<body>
  <div id="container">
    <div class="box">
      <img src="C:\Users\JLZ\Pictures\Sketchpad.png">
    </div>
    <div class="box">
      <img src="C:\Users\JLZ\Pictures\cat.jpg">
    </div>
    <div class="box">
      <img src="C:\Users\JLZ\Pictures\th1.jpg">
    </div>
    <div class="box">
      <img src="C:\Users\JLZ\Pictures\test.jpg">
    </div>
    <div class="box">
      <img src="C:\Users\JLZ\Pictures\查看.jpg">
    </div>
    <div class="box">
      <img src="C:\Users\JLZ\Pictures\下载.png">
    </div>
    <div class="box">
      <img src="C:\Users\JLZ\Pictures\th1.jpg">
    </div>
    <div class="box">
      <img src="C:\Users\JLZ\Pictures\test.jpg">
    </div>
    <div class="box">
      <img src="C:\Users\JLZ\Pictures\查看.jpg">
    </div>
    <div class="box">
      <img src="C:\Users\JLZ\Pictures\下载.png">
    </div>
    <div class="box">
      <img src="C:\Users\JLZ\Pictures\test.jpg">
    </div>
  </div>
</body>

<script>
  window.onload = () => {
    imgLocation('container', 'box')
  }

  function imgLocation(parent, content) {
    const cparent = document.getElementById(parent)
    const ccontent = getChildElement(cparent, content)

    const imgWidth = ccontent[0].offsetWidth
    const num = Math.floor(document.documentElement.clientWidth / imgWidth)
    cparent.style.width = `${imgWidth * num}px`

    const BoxHeightArr = []
    for (var i = 0; i < ccontent.length; i++) {
      if (i < num) {
        //第一行的图片
        BoxHeightArr.push(ccontent[i].offsetHeight)
        // 起初通过.offsetHeight获取的高度与实际高度不一致,原因在于left的div里有img
        // 必须等到页面加载完毕之后才能正确获取content的高度,所以在onload方法里获取content高度才是实际的高度
        // console.log(ccontent[i].offsetHeight);
      }
      else { 
        const minHeight = Math.min.apply(null, BoxHeightArr)
        const minIndex = BoxHeightArr.indexOf(minHeight)
        //摆放图片的位置
        ccontent[i].style.position = 'absolute'
        ccontent[i].style.top = minHeight + 'px'
        ccontent[i].style.left = ccontent[minIndex].offsetLeft + 'px'
        //更新这一列的高度
        BoxHeightArr[minIndex] = BoxHeightArr[minIndex] + ccontent[i].offsetHeight
      }
    }
  }

  function getChildElement(parent, child) {
    const childArr = []
    const allChild = parent.getElementsByTagName('*')
    for (var i = 0; i < allChild.length; i++) {
      if (allChild[i].className === child) {
        childArr.push(allChild[i])
      }
    }
    return childArr
  }
</script>
</html>
相关推荐
努力写代码的熊大1 小时前
stack、queue与priority_queue的用法解析与模拟实现
java·前端·javascript
im_AMBER1 小时前
React 06
前端·javascript·笔记·学习·react.js·前端框架
wyzqhhhh2 小时前
前端常见的设计模式
前端·设计模式
IT_陈寒2 小时前
React 19重磅前瞻:10个性能优化技巧让你少写30%的useEffect代码
前端·人工智能·后端
今天没有盐3 小时前
💕CSS 基础入门指南💕:选择器与文本样式
前端·html·响应式设计
云枫晖3 小时前
Webpack系列-Entry入口
前端·webpack
mustfeng3 小时前
VCS & Verdi 2023安装
java·服务器·前端
Mintopia4 小时前
🌐 数据合规框架下的 WebAIGC 训练数据处理技术规范
前端·javascript·aigc
骥龙4 小时前
2.6、Web漏洞挖掘实战(下):XSS、文件上传与逻辑漏洞深度解析
前端·xss
用户433845375694 小时前
Promise深度解析,以及简易版的手写实现
前端