zoukankan      html  css  js  c++  java
  • js中瀑布式布局插件masonry与翻页插件infinitescroll结合

    转自:http://blog.csdn.net/feng2375/article/category/324578

    首先在页面中引入
    <script src="jquery-1.7.1.min.js"></script>
    <script src="jquery.masonry.min.js"></script>
    <script src="jquery.infinitescroll.js"></script>

    排列body中的内容:
    <BODY>  <div id="container">
          <div class="item">a a a a a  a</div>
          <div class="item">a a a a a  a</div>
          <div class="item">a a a a a  a</div>
          <div class="item">a a a a a  a</div>

      </div>
    </BODY>

    在js中调用插件:
    <script type="text/javascript">
      $(function(){
        $('#container').masonry({
          // options 设置选项
          itemSelector : '.item',//class 选择器
          columnWidth : 240 ,//一列的宽度 Integer
              isAnimated:true,//使用jquery的布局变化  Boolean
              animationOptions:{
                //jquery animate属性 渐变效果  Object { queue: false, duration: 500 }
              },
              gutterWidth:0,//列的间隙 Integer
              isFitWidth:true,// 适应宽度   Boolean
              isResizableL:true,// 是否可调整大小 Boolean
              isRTL:false,//使用从右到左的布局 Boolean
      });
    });
    </script>
    当需要排列图片div时:
    需要调用:
    <script>
    var $container = $('#container');
    $container.imagesLoaded(function(){
      $container.masonry({
        itemSelector : '.item',
        columnWidth : 240
      });
    });
    </script>

    调用masonry插件的方法格式是:$('#container').masonry( 'methodName', [optionalParameters] )

    例如:
    .masonry( 'appended', $content, isAnimatedFromBottom )//触发添加到container的项目的布

    局.masonry( 'destroy' )// 完全移除masonry的功能 返回到元素预初始化状态
    .masonry( 'layout', $items, callback )// 指定项目的布局
    .masonry( 'option', options ) //设置option
    .masonry( 'reloadItems' ) //重新聚合所有项目以当前的顺序
    .masonry( 'reload' ) //用于预先考虑或者插入项目 .masonry( 'reloadItems' )的简化版
    .masonry( 'remove', $items ) //从masonry实例或dom中移除项目

    调用infinitescroll插件:
    $container.infinitescroll({
            navSelector : '#page-nav', //分页导航的选择器
            nextSelector : '#page-nav a', //下页连接的选择器
            itemSelector : '.box', //你要检索的所有项目的选择器
            loading: {
                    finishedMsg: 'No more pages to load.',//结束显示信息
                    img: 'http://i.imgur.com/6RMhx.gif'//loading图片
            }
    },
    //作为回调函数触发masonry
    function( newElements ) {
    // 当加载时隐藏所有新项目
            var $newElems = $( newElements ).css({ opacity: 0 });
    // 在添加到masonry布局之前保证图片载入
            $newElems.imagesLoaded(function(){
    // 现在可以显示所有的元素了
            $newElems.animate({ opacity: 1 });
            $container.masonry( 'appended', $newElems, true );
            });
    }
    );

  • 相关阅读:
    码农雷林鹏:php环境搭建
    HashMap底层实现原理
    Java基础面试题
    ==和equals的区别,为什么重写equals要重写hashCode
    Java8 函数式接口,方法引用,stream
    ArrayList、Vector、LinkedList的区别
    第二章——信息的表示和处理
    第一章——计算机系统漫游
    通过zuul修改请求参数——对请求参数进行解密
    Java 扫描实现 Ioc 动态注入,过滤器根据访问url调用自定义注解标记的类及其方法
  • 原文地址:https://www.cnblogs.com/irelands/p/2451262.html
Copyright © 2011-2022 走看看