瀑布流简单实现

发布于 2023-05-04 19:20:17 字数 3025 浏览 60 评论 0

瀑布流画册,主要是要求出列数,超出列数的图片,按照顺序,每次找到高度最小的一列,进行排列

<div>
  <div class="item"><img src="https://avatars.githubusercontent.com/u/11458263?s=80&u=8abd594f236f381da9cbe70bade832663ecb4bd0&v=4"></div>
  <div class="item"><img src="https://static.jsbin.com/images/dave.min.svg"></div>
  <div class="item"><img src="https://images.unsplash.com/photo-1679068476679-5057c5c5d256?ixlib=rb-4.0.3&ixid=MnwxMjA3fDB8MHxlZGl0b3JpYWwtZmVlZHw0fHx8ZW58MHx8fHw%3D&auto=format&fit=crop&w=500&q=60" alt=""></div>
  <div class="item"><img src="https://images.unsplash.com/photo-1679068476679-5057c5c5d256?ixlib=rb-4.0.3&ixid=MnwxMjA3fDB8MHxlZGl0b3JpYWwtZmVlZHw0fHx8ZW58MHx8fHw%3D&auto=format&fit=crop&w=500&q=60" alt=""></div>
  <div class="item"><img src="https://static.jsbin.com/images/dave.min.svg"></div>
  <div class="item"><img src="https://avatars.githubusercontent.com/u/11458263?s=80&u=8abd594f236f381da9cbe70bade832663ecb4bd0&v=4"></div>
  <div class="item"><img src="https://avatars.githubusercontent.com/u/11458263?s=80&u=8abd594f236f381da9cbe70bade832663ecb4bd0&v=4"></div> <div class="item"><img src="https://avatars.githubusercontent.com/u/11458263?s=80&u=8abd594f236f381da9cbe70bade832663ecb4bd0&v=4"></div> <div class="item"><img src="https://avatars.githubusercontent.com/u/11458263?s=80&u=8abd594f236f381da9cbe70bade832663ecb4bd0&v=4"></div> <div class="item"><img src="https://avatars.githubusercontent.com/u/11458263?s=80&u=8abd594f236f381da9cbe70bade832663ecb4bd0&v=4"></div> <div class="item"><img src="https://avatars.githubusercontent.com/u/11458263?s=80&u=8abd594f236f381da9cbe70bade832663ecb4bd0&v=4"></div> <div class="item"><img src="https://avatars.githubusercontent.com/u/11458263?s=80&u=8abd594f236f381da9cbe70bade832663ecb4bd0&v=4"></div>
</div>
#waterfall {
  width: 100%;
  margin: 0 auto;
}

.item {
  width: 30%;
  margin: 10px;
  float: left;
  overflow: hidden;
}

.item img {
  width: 100%;
  height: auto;
}
window.onload = function() {
  var waterfall = document.getElementById("waterfall");
  var items = waterfall.getElementsByClassName("item");
  var gap = 10;
  var itemWidth = items[0].offsetWidth + gap;
  var columns = Math.floor(waterfall.offsetWidth / itemWidth);
  var heights = [];

  for (var i = 0; i < items.length; i++) {
    if (i < columns) {
      heights.push(items[i].offsetHeight);
    } else {
      var minHeight = Math.min.apply(null, heights);
      var minIndex = heights.indexOf(minHeight);
      items[i].style.position = "absolute";
      items[i].style.top = minHeight + "px";
      items[i].style.left = minIndex * itemWidth + "px";
      heights[minIndex] += items[i].offsetHeight + gap;
    }
  }
};

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。
列表为空,暂无数据

关于作者

0 文章
0 评论
23 人气
更多

推荐作者

qq_eQNo9e

文章 0 评论 0

内心旳酸楚

文章 0 评论 0

mb_BlPo2I8v

文章 0 评论 0

alipaysp_ZRaVhH1Dn

文章 0 评论 0

alipaysp_VP2a8Q4rgx

文章 0 评论 0

    我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
    原文