Masonry实现JS瀑布流

瀑布流布局在很多网站都有应用,也是从国外流行起来的一种不规则布局,想要在网页端实现瀑布流效果可以借用Masonry插件。


一、引入Masonry文件

可以去官网下载到本地,也可以直接引入CDN,还可以用npm等包管理工具直接下载。此处用CDN引入。

官网地址:http://masonry.desandro.com

<script src="https://npmcdn.com/masonry-layout@4.0/dist/masonry.pkgd.js"></script>
<!-- or -->
<script src="https://npmcdn.com/masonry-layout@4.0/dist/masonry.pkgd.min.js"></script>


二、编写html结构和样式

<div id="container">
  <div class="item">
    <img src="touxiang-@3x.png">
  </div>
  <div class="item">
    <img src="test.png">
  </div>
  <div class="item">
    <img src="touxiang-@3x.png">
  </div>
  <div class="item">
    <img src="test.png">
  </div>
  <div class="item">
    <img src="touxiang-@3x.png">
  </div>
  <div class="item">
    <img src="test.png">
  </div>   
</div>
<style>
    #container{
      margin: 0 auto;
      background: red;
    }
    .item{
      /*width: 100px;*/     /* 控制每个图片宽度 */
      margin: 2px;
    }
</style>


三、初始化插件

$('#container').masonry({
    itemSelector: '.item',
    isAnimated: true,
    // columnWidth: 450,     
    isFitWidth: true     // 自适应宽度
  });
下面介绍下主要参数:

itemSelector     class选择器,默认'.item',这个表示每个块的选择器 

columnWidth     一列的宽度 

isAnimated     使用jquery的布局变化,默认true 

animationOptions     animate属性渐变效果(Object { queue: false, duration: 500 }) 

gutterWidth     列的间隙 Integer 

isFitWidth     自适应浏览器宽度Boolean 

isResizableL     是否可调整大小 Boolean 

isRTL     使用从右到左的布局 Boolean

一般只需要用到:itemSelector、isFitWidth即可。先将每个需要自适应的元素放入div,并给定样式,此处是item。通过css可以控制每个item的宽度。

isFitWidth默认为false,开启后容器container将使用自适应宽度。然后用css控制居中margin:0 auto;即可。


  • 3
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在使用 Masonry 布局的时候,图片的高度不一致可能导致瀑布流重叠的问题。解决这个问题的方法是通过给每个元素设置宽度,并根据图片的原始大小设置元素的高度。 具体实现步骤如下: 1. 获取所有图片元素的原始大小。 可以通过创建一个 Image 对象,使用其 onload 事件在图片加载完成后获取图片的原始大小。 ```javascript var img = new Image(); img.onload = function() { console.log('图片原始大小:' + this.width + 'x' + this.height); }; img.src = 'http://example.com/image.jpg'; ``` 2. 计算每个元素的高度。 在获取到图片的原始大小之后,可以根据元素的宽度和图片的宽高比计算出元素的高度。 ```javascript var elementWidth = 200; // 元素宽度 var imageWidth = img.width; var imageHeight = img.height; var elementHeight = imageHeight / imageWidth * elementWidth; ``` 3. 设置每个元素的高度。 通过遍历所有元素,设置其高度即可。 ```javascript var elements = document.querySelectorAll('.item'); for (var i = 0; i < elements.length; i++) { elements[i].style.height = elementHeight + 'px'; } ``` 以上是一种简单的解决方案,但可能存在一些问题,例如: - 如果图片加载较慢,会导致布局变化时出现闪烁。 - 如果图片的宽高比很大,会导致元素的高度很高,影响布局效果。 为了解决这些问题,可以使用一些插件或库来实现瀑布流布局,例如: - Isotope:一个功能强大的瀑布流布局库,支持过渡效果和筛选功能。 - Packery:一个基于 Draggabilly 的瀑布流布局库,支持动态布局和拖拽功能。 - Waterfall:一个轻量级的瀑布流布局插件,支持自适应和懒加载功能。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值