瀑布流布局

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>
相关推荐
乌索普-3 分钟前
基于vue2的简易购物车
开发语言·前端·javascript
走粥5 分钟前
使用indexOf查找对象结合Pinia持久化引发的问题
开发语言·前端·javascript
北寻北爱15 分钟前
前端加密解密- base64、md5、sha256、AES
前端·vue.js
柒.梧.15 分钟前
Redis通用命令+五大核心数据结构
前端·bootstrap·html
Refly26 分钟前
【微信接入 OpenClaw 龙虾🦞】10分钟手把手教程完成接入,Claude 模型无限使用
前端·微信·github
恋猫de小郭32 分钟前
为什么中转渠道的顶级模型会不好用?这是一个技术问题
前端·人工智能·ai编程
发现一只大呆瓜37 分钟前
React-深度拆解 React路由:从实战进阶到底层原理
前端·react.js·面试
不甜情歌39 分钟前
搞懂 Promise:告别回调嵌套,再也不怕异步代码乱成麻
前端·javascript
野草arthas41 分钟前
什么是视觉层次?为什么需要它?
前端
发现一只大呆瓜1 小时前
React-手把手带你实现 Keep-Alive 效果
前端·react.js·面试