瀑布流布局

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>
相关推荐
蜗牛攻城狮25 分钟前
CSS中的 `dvh` 与 `vh`: 深入理解视口单位
前端·css
啥都不懂的小小白31 分钟前
Shell脚本编程入门:从零基础到实战掌握
前端·shell
东东5161 小时前
校园短期闲置资源置换平台 ssm+vue
java·前端·javascript·vue.js·毕业设计·毕设
qq_419854051 小时前
富文本编辑器
前端
悟能不能悟1 小时前
VUE的国际化,怎么实现
前端·javascript·vue.js
Mr Xu_1 小时前
解决 Vue + Axios 热更新导致响应拦截器重复注册的问题
前端·javascript·vue.js
岁岁种桃花儿1 小时前
NodeJs从入门到上天:什么是Node.js
前端·node.js
colicode1 小时前
语音报警接口开发参考:紧急情况下快速调用语音API发送安全警报
前端·语音识别
夏河始溢1 小时前
一八四、Zustand 状态管理详解、与 Redux、MobX 的对比分析
前端·javascript·react.js·状态管理·zustand
Code小翊1 小时前
TypeScript 核心语法速查
前端·javascript·typescript