转载至 http://wuyuans.com/2013/08/jquery-masonry-infinite-scroll/

jQuery无限载入瀑布流

好久没更新日志了,一来我比较懒,二来最近也比较忙,惭愧啊。这次我要写的是关于瀑布流网页布局的方法,在网页布局中瀑布流算比较新颖的方式,最近我也试了一下,把本站的电影资源独立出来做了一个子站。因为电影都是以海报形式展示的,图片会比较多,瀑布流应该会比较合适,最后的完成品在这里:Wuyuan's Movie。使用jQuery实现,用到三个插件:Masonry、Infinite Scroll和imagesLoaded。

1.Masonry

Masonry是一款网页布局插件,能帮你自动排列网页元素,比如div和li,我这里使用li来放电影资源。
Masonry主页:http://masonry.desandro.com/
github项目:https://github.com/desandro/masonry
用法很简单,在他主页里有例子。

var $container = $('#container');

// initialize

$container.masonry({

columnWidth:200,//每列的宽度,不设就按第一个计算

itemSelector:'.item',//需要排列的元素

gutter:20,//每列的间隙

});

2.Infinite Scroll

Infinite Scroll是一款自动载入的插件,当滚动条靠近底部时会自动读取下一页的元素,并添加到相关容器里,配合Masonry实现无限载入。
Infinite Scroll主页:http://www.infinite-scroll.com/
github项目:https://github.com/paulirish/infinite-scroll
用法也很简单,我这里列举一些常用的参数。

$('.selector').infinitescroll({

//导航所在容器

navSelector:"div.navigation",

//导航中下一页的链接地址

nextSelector:"div.navigation a:first",

//需要添加的新元素

itemSelector:"div.post",

//动画效果

animate:false,

//动画效果长度

extraScrollPx:150,

//导航条到底部的距离

pixelsFromNavToBottom:200,

},

function( newElements ){

//添加新元素

})

);

很多文章中都说extraScrollPx是触发加载的滚动条剩余长度,但我改了该值后没什么反应,后来看了代码才发现这个只是动画效果触发是滚动条向下滚动的距离而已,真正可以触发加载的是下面这个pixelsFromNavToBottom,他表示导航栏到底部的距离,infinitescroll会在下拉到导航栏附近触发自动加载,也就是当滚动条剩余长度小于pixelsFromNavToBottom这个值时触发加载。后面那个函数是读取到新元素的加载函数,需要和Masonry配合,我将在下面讲到。

3.imagesLoaded

在用Masonry加载图片时会出现一个问题,因为图片的加载比较慢,Masonry会读取不到图片的高度而错误的计算元素的高度,这样就会使布局重叠。解决办法就是在图片全部加载后再使用Masonry布局,这就要用到imagesLoaded这个插件,在低版本jQuery中他是内置的函数,现在已经独立出来作为一个插件调用了。
imagesLoaded主页:http://desandro.github.io/imagesloaded/
github项目:https://github.com/desandro/imagesloaded

$('#container').imagesLoaded(function(){

// images have loaded

});

4.实际应用

将上面三个插件组合到一起就可以做出无限加载的瀑布流了,下面以我的子站为例子说一下。我所有资源使用ul和li来组织,如下。

<ulid="masonry">

<liclass="box"></li>

<liclass="box"></li>

<liclass="box"></li>

</ul>

<divid="npage"><ahref="http://movie.wuyuans.com/2.html">下一页</a></div>

下一页的链接在#npage中,下面是js代码。

    1. <scripttype="text/javascript"src="/static/jquery-1.7.1.js"></script>
    2. <scripttype="text/javascript"src="/static/masonry.pkgd.min.js"></script>
    3. <scripttype="text/javascript"src="/static/jquery.infinitescroll.min.js"></script>
    4. <scripttype="text/javascript"src="/static/imagesloaded.pkgd.min.js"></script>
    5. <scripttype="text/javascript">
    6. $(function(){
    7. var $container = $('#masonry');
    8. $container.imagesLoaded(function(){
    9. $container.masonry({
    10. columnWidth:235,
    11. itemSelector:'.box',
    12. gutter:20
    13. });
    14. });
    15. $container.infinitescroll({
    16. navSelector :"#npage",
    17. nextSelector :"#npage a",
    18. itemSelector :".box",
    19. pixelsFromNavToBottom:300
    20. },
    21. function( newElements ){
    22. //首先隐藏
    23. var $newElems = $( newElements ).css({ opacity:0});
    24. $newElems.imagesLoaded(function(){
    25. //布局时显示
    26. $newElems.animate({ opacity:1});
    27. $container.masonry('appended', $newElems,true);
    28. });
    29. });
    30. });
    31. </script>

jQuery无限载入瀑布流 【转载】的更多相关文章

  1. jquery实现无限滚动瀑布流实现原理

    现在类似于pinterest这类的表现效果很火,其实我比较中意的是他的布局效果,而不是那种瀑布流. 虽然我不是特别喜欢这种瀑布流的表现样式,但是还是写了几篇关于无限滚动瀑布流效果的文章,Infinit ...

  2. jQuery动态网格瀑布流插件Masonry

    Masonry是一款非常强大的jQuery动态网格布局插件,可以帮助开发人员快速开发瀑布流界面效果.和CSS中float的效果不太一样的地方在于,float先水平排列,然后再垂直排列,使用Masonr ...

  3. jQuery淡入淡出瀑布流效果

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...

  4. jquery插件实现瀑布流

    jquery插件实现瀑布流<!DOCTYPE html><html lang="en"><head> <meta charset=&quo ...

  5. Jquery实现图片瀑布流思路-简单版

    目录 Jquery实现图片瀑布流思路-简单版 1.预备 2.开始 1.声明 2.主体 3.窗体大小改变事件 Jquery实现图片瀑布流思路-简单版 注意:本篇文章基于知道每张图片的实际尺寸的情况下 特 ...

  6. 基于jQuery的简易瀑布流实现

    <!doctype html> <html> <head> <meta charset="UTF-8"> <title> ...

  7. Masonry + Ajax 实现无限刷新瀑布流

    效果就如我的个人站yooao.cc,把我实现的思路分享给大家. Masonry渲染页面如果有图片时需要imagesLoaded辅助,不然有可能会造成布局重叠. 一个大体的思路:前端取得最后一篇文章的i ...

  8. jQuery插件之-瀑布流插件

    jquery.wookmark.js 一个实现瀑布流自适应宽度布局的jQuery插件—jquery.wookmark.js , wookmark使用非常简单到只需要一句代码就能实现,除此之外,当页面宽 ...

  9. jquery练习之瀑布流

    最近有空简单学习了下瀑布流,写完后想和大家一起分享下,但我知道我的代码有很多缺陷不足,希望多多包涵.(纯属兴趣非专业学习人士) 众所周知,瀑布流大概分为2种,一种是浮动式的瀑布流,一种是定位式的瀑布流 ...

随机推荐

  1. hdu 4788 Hard Disk Drive (水题)

    题意: Input The first line contains an integer T, which indicates the number of test cases. For each t ...

  2. C++中gSOAP的使用

    目录 SOAP简介 gSOAP 准备工作 头文件 构建客户端应用程序 生成soap源码 建立客户端项目 构建服务端应用程序 生成SOAP源码 建立服务端项目 打印报文 SOAP测试 项目源码 本文主要 ...

  3. matlab与python scipy.signal中 freqs freqz 中w,什么时候是角频率,什么时候是真实的工程中使用的采样频率Hz,如何转化

    matlab与python scipy.signal中的freqs,freqz频率分析函数,输出的w,有时候是角频率,有时候是真实频率,容易搞混,这里对比一下. 0.  精要总结: 1) freqs: ...

  4. ZooKeeper 集群搭建 Error contacting service. It is probably not running.

    搭建环境:Centos 7 虚拟机 3台 按照此教程搭建:https://www.ilanni.com/?p=11393 之后出现错误:Error contacting service. It is ...

  5. docker中镜像的作用

    镜像原理镜像 镜像到底是什么?镜像是一种轻量级.可执行的独立软件包,用来打包软件运行环境和基于运行环境开发的软件,它包含运行某个软件所需的所有内容,包括代码.运行时.库.环境变量和配置文件.1.Uni ...

  6. kubernetes常见日志采集问题和解决方案分析

    传统日志与kubernetes日志对比 传统服务 目录固定 重启不会丢失 不用关注标准与错误日志输出 容器服务 节点不固定 重启服务会漂移 需要关注标准与错误日志输出 日志文件重启会丢失 日志目录不固 ...

  7. Java多线程 | 02 | 线程同步机制

    同步机制简介 ​ 线程同步机制是一套用于协调线程之间的数据访问的机制.该机制可以保障线程安全.Java平台提供的线程同步机制包括: 锁,volatile关键字,final关键字,static关键字,以 ...

  8. WPF进阶技巧和实战09-事件(2-多点触控)

    多点触控输入 多点触控输入和传统的基于比的输入的区别是多点触控识别手势,用户可以移动多根手指以执行常见的操作,放大,旋转,拖动等. 多点触控的输入层次 WPF允许使用键盘和鼠标的高层次输入(例如单击和 ...

  9. Python - 一行代码查看当前操作系统默认的编码标准

    一句代码 在 cmd 中执行 > python3 -c 'import locale; print(locale.getpreferredencoding())' UTF-8

  10. 【JAVA】笔记(6)--- toString方法;equals方法;finalize方法;package与import;内部类;

    toString: 1.每创建一个类时,都要重写 toString 方法,这是敲代码的基本素养: 2.重写规则:简单明了: 3.String 类中也有toString方法(SUN公司写的): equa ...