jQuery瀑布流插件 Masonry

所属分类:UI-布局

 194286  208  查看评论 (64)
jQuery瀑布流插件 Masonry ie兼容6

我们可以使用 jQuery 的 Masonry 插件来实现这种页面形式,下面介绍一下方法。

1,分别下载 jQuery 与 Masonry ,然后把他们都加载到页面中使用。

加载代码:

<script src="http://libs.baidu.com/jquery/1.8.3/jquery.min.js"></script>
<script src="http://jq22.qiniudn.com/masonry-docs.min.js"></script>


解释:很简单,就是把下载之后的脚本文件嵌入到你想使用瀑布流形式的页面中,注意文件的名称与路径,根据你自己的实际情况修改。


2,页面代码

<div id="masonry" class="container-fluid">
  <div class="box"><img src="http://jq22.com/images/1.jpg"></div>
  <div class="box"><img src="http://jq22.com/images/2.jpg"></div>
  <div class="box"><img src="http://jq22.com/images/3.jpg"></div>
  <div class="box"><img src="http://jq22.com/images/4.jpg"></div>
  <div class="box"><img src="http://jq22.com/images/5.jpg"></div>
  ...
</div>


解释:把每个小内容块放在一个拥有相关类的容器里,然后把所有的内容块放在一个大的容器里,这里我们把内容块图片放在一个拥有 .box 类的 <div> 标签里,然后把他们又使用带有 #masonry ID 的 <div> 里面,一会儿我们会用 #masonry ID 和 .box 类来触发使用瀑布流。


3,样式代码

.container-fluid {
  padding: 20px;
  }
.box {
  margin-bottom: 20px;
  float: left;
  width: 220px;
  }
  .box img {
  max-width: 100%
}

解释:针对第二步的页面代码,我们需要添加一点样式,.box 类我们添加了浮动属性,还设置了他的宽度。


4,在页面中启用瀑布流形式的脚本代码

$(function() {
    var $container = $('#masonry');
    $container.imagesLoaded(function() {
        $container.masonry({
                itemSelector: '.box',
                gutter: 20,
                isAnimated: true,
            });
     });
});

解释:这里我们首先定位想使用瀑布流的大容器是什么,这里就是带有 #masonry ID 的 <div> 标签,在 var $container = $('#masonry'); 这行代码中定义。然后我们还要说明瀑布流里的每个内容块容器上共同的类是什么,这里就是带有 .box 类的 <div> 标签,在itemSelector : '.box', 这行代码中定义。


gutter: 20, 这行代码定义了内容块之间的距离是 20 像素,isAnimated: true, 这行代码可以打开动画选项,也就是当改变窗口宽度的时候,每行显示的内容块的数量会有变化,这个变化会使用一种动画效果。


(感谢网友阿富)提供不居中显示!

我的一个笨方法:

$(function() {
    var $objbox = $("#masonry");
    var gutter = 25;
    var centerFunc, $top0;
    $objbox.imagesLoaded(function() {
        $objbox.masonry({
            itemSelector: "#masonry > .box",
            gutter: gutter,
            isAnimated: true
        });
        centerFunc = function() {
            $top0 = $objbox.children("[style*='top: 0']");
            $objbox.css("left", ($objbox.width() - ($top0.width() * $top0.length + gutter * ($top0.length - 1))) / 2).parent().css("overflow", "hidden");
        };
        centerFunc();
    });
    var tur = true;
    $(window).resize(function() {
        if (tur) {
            setTimeout(function() {
                tur = true;
                centerFunc();
            },
            1000);
            tur = false;
        }
    });
});
相关插件-布局

响应式后后台管理模板

基于Bootstrap的HTML后台管理模板
  布局
 18171  150

响应式html5模板

响应式html5模板
  布局
 8128  53

jQuery bootstrap响应式网站模板

jQuery bootstrap响应式销售模板全套完整代码,简洁大气。
  布局
 7767  138

jQuery CSS3全屏双面板内容切换UI设计

这是一款效果非常炫酷的全屏双面板内容切换UI设计效果。该UI设计使用CSS3和jQuery来制作双面板效果,左右两个面板可以通过箭头按钮来相应切换具体的内容,在内容切换时带有一些3D效果,非常炫酷。
  布局
 5656  58

讨论这个项目(64)回答他人问题或分享插件使用方法奖励jQ币

    Lonely me 0
    2017/8/14 11:13:15

    谁有做好的全套 给我一份

    回复
    殇丶 0
    2017/8/2 14:39:10

    这个支持IE7不?楼主会不会刷新一下就打乱一次排序的js?  类似 http://huaban.com/ 

    水平太低,不会仿 回复
    殇丶 0
    2017/8/2 14:38:03

    这个支持IE7不?楼主会不会刷新一下就打乱一次排序的js?  类似 http://huaban.com/ 

    水平太低,不会仿 回复
    晨曦^ 0
    2017/7/25 10:33:32
    用ajax二次加载的时候排版就乱了,div重叠。不实用 回复
    懒斌 0
    2017/6/28 22:37:28

    按照这个来你们都没问题吗?一直报 $container.imagesLoaded is not a function

        隽永东方设计-Leo0
        2017/6/29 17:24:29

        一样

        somebody0
        2017/6/30 11:17:23

        没问题

        你这个应该是直接用的地址引用的js文件吧  最好下下来在自己项目里引用

        隽永东方设计-Leo0
        2017/6/30 13:47:55

        就是下载下来的

    回复
    dlite_426 0
    2017/5/31 15:40:20

    为什么底部不自动填充啊

    回复
    碧海潮生 0
    2017/5/24 14:03:53

    使用appended添加新的元素不显示:

    $('#masonry').append($elems).masonry('appended', $elems);

    个数是对的:

    var allelems = $('#masonry').masonry('getItemElements');  
    alert(allelems.length);
    回复
    碧海潮生 0
    2017/5/24 9:27:54

    请问如何让div滚动,而不是页面出现滚动条

    回复
    碧海潮生 0
    2017/5/23 16:53:10
    ie8根本不支持好吧 回复
    碧海潮生 0
    2017/5/23 16:48:56

    对象不支持“imagesLoaded”属性或方法 。什么原因?

    回复
取消回复