瀑布流布局

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>
相关推荐
恋猫de小郭1 小时前
Android 宣布 Runtime 编译速度史诗级提升:在编译时间上优化了 18%
android·前端·flutter
莓莓儿~1 小时前
Next.js 14 App Router数据获取开发手册
开发语言·前端·javascript
文心快码BaiduComate1 小时前
AI Coding老跑偏?用Comate Rules功能,少走十年弯路!
前端·架构·前端框架
PineappleCoder1 小时前
WebP/AVIF 有多香?比 JPEG 小 30%,<picture>标签完美解决兼容性
前端·面试·性能优化
Kaze_story1 小时前
Vue第五章(1):scoped、组件通信
前端·javascript·vue.js
hayzone1 小时前
Git 配置与使用全攻略(含工作流对比与 AI 协作)
前端
匠心网络科技1 小时前
前端框架-Vue为何开发更高效?
前端·javascript·vue.js·前端框架
大风起兮云飞扬丶1 小时前
react大列表更新时优化
前端·react.js·前端框架
0思必得02 小时前
[Web自动化] HTML5常见新增标签
前端·python·自动化·html5·web自动化
Alair‎2 小时前
103React数据处理
开发语言·前端·javascript