前两天写的文章《纯手工打造漂亮的垂直时间轴,使用最简单的HTML+CSS+JQUERY完成100个版本更新记录的华丽转身!》受到很多网友的喜爱,今天特别推出姊妹篇《纯手工打造漂亮的瀑布流,五大插件一个都不少Bootstrap+jQuery+Masonry+imagesLoaded+Lightbox!》,希望大家喜欢!

前言

FineUI控件库发展至今已经有 5 个年头,目前论坛注册的QQ会员 5000 多人,捐赠用户 500 多人(捐赠用户转化率达到10%以上,在国内开源领域相信这是一个梦幻数字!也足以证明FineUI旺盛的生命力!)。在这 5 年七年,FineUI总共发布了 100 多个版本!也积攒了大量的典型案例。

然而一直以来,FineUI的典型案例都是在论坛上以帖子的形式进行展示,没有一个集中展示的地方。今天我们就使用前段时间比较流行的瀑布流来解决FineUI典型案例的展示问题。最终的显示效果如下图所示。

五大插件简介

为了制作FineUI的《典型案例》页面,我们综合运用了Bootstrap+jQuery+Masonry+imagesLoaded+Lightbox五大插件,下面先对这 5 个插件进行简单的介绍。

1. Bootstrap:强大的CSS框架,由Twitter的开发工程师推出,不仅仅是960布局,而且包含很多很多拿来就用的漂亮样式。从Bootstrap推出第一个版本作者就开始使用,http://twitter.github.io/bootstrap/

2. jQuery:JavaScript框架,业界事实的标准。http://jquery.com/

3. Masonry:制作瀑布流布局的JavaScript库。http://masonry.desandro.com/

4. imagesLoad:监测图片是否加载完毕的JavaScript库。https://github.com/desandro/imagesloaded

5. Lightbox:以弹框形式集中展示图片的JavaScript库。http://lokeshdhakar.com/projects/lightbox2/

用Bootstrap打底

首先为每个案例准备1-2张截图、案例名称以及案例作者,并创建简单的HTML布局如下:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
< div  id = "masonry"  class = "container-fluid" >
 
     < div  class = "thumbnail" >
         < div  class = "imgs" >
             < img  src = "./images/2426.png"  />
         </ div >
         < div  class = "caption" >
             < div  class = "title" >简单OA管理系统</ div >
             < div  class = "content" >
                 
             </ div >
             < div  class = "author" >
                 by < a  target = "_blank"  href = "http://fineui.com/bbs/home.php?mod=space&uid=2426" >小小生</ a >
             </ div >
         </ div >
     </ div >
     
</ div >

为HTML元素定义简单的CSS样式:

<style>
     #masonry
     {
         padding : 0 ;
         min-height : 450px ;
         margin : 0  auto ;
     }
     #masonry .thumbnail
     {
         width : 330px ;
         margin : 20px ;
         padding : 0 ;
         border-width : 1px ;
         -webkit-box-shadow: 0  6px  12px  rgba( 0 , 0 , 0 , 0.175 );
                 box-shadow: 0  6px  12px  rgba( 0 , 0 , 0 , 0.175 );
     }
     #masonry .thumbnail .imgs
     {
         padding : 10px ;
     }
     #masonry .thumbnail .imgs img
     {
         margin-bottom : 5px ;
     }
     #masonry .thumbnail . caption
     {
         background-color : #fff ;
         padding-top : 0 ;
         font-size : 13px ;
     }
     #masonry .thumbnail . caption  .title
     {
         font-size : 13px ;
         font-weight : bold ;
         margin : 5px  0 ;
         text-align : left ;
     }
     #masonry .thumbnail . caption  .author
     {
         font-size : 11px ;
         text-align : right ;
     }
     
</style>

此时的页面看起来如下图所示(源代码在 index_1.html 中,文章最后会提供下载地址)。

用Masonry+imagesLoaded创建瀑布流

由于列表中包含图片,我们需要所有图片加载完毕后再调用Masonry的瀑布流布局,从而方式列表中的元素重叠在一起。为上述页面添加如下简单的JavaScript代码。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
<script>
     $( function () {
     
         var  masonryNode = $( '#masonry' );
         masonryNode.imagesLoaded( function (){
             masonryNode.masonry({
                 itemSelector: '.thumbnail' ,
                 isFitWidth: true
             });
         });
         
         
     });
</script>

此时页面显示效果如下图所示(源代码在 index_2.html 中,文章最后会提供下载地址)。

手工创建随机序列和延迟加载效果

如果图省事,上面就已经完成了全部的工作,页面已经创建出来了,瀑布流效果看起来还不错。不过程序员一定要精益求精,我们还要认真考虑如下两个问题:

1. 目前有35个案例,每个案例有1-2张图片,要等这80几张图片全部加载完毕再生成瀑布流,需要的时间会很长;

2. 由于这些案例都是平级的,我们不能手工引入顺序,所以需要随机显示。

针对第一个问题,Masonry幸好有相应的 appended 方法,来在现有的瀑布流布局基础上添加新的元素,而不会影响已经存在的布局,其调用方法如下所示。

1
2
3
4
5
6
7
8
9
// 首先将新元素添加到页面容器中
 
masonryNode.append(newItems);
// 等待新元素中的图片加载完毕
newItems.imagesLoaded( function (){
 
// 调用瀑布流布局的appended方法
     masonryNode.masonry( 'appended' ,  newItems);
});

那么在什么时间调用呢?上一篇文章《纯手工打造漂亮的垂直时间轴,使用最简单的HTML+CSS+JQUERY完成100个版本更新记录的华丽转身!》已经给出了相应的代码,在页面的滚动条滚动到页面底部时加入新的元素。

1
2
3
4
5
6
7
8
9
10
11
$(window).scroll( function () {
                 
     if ($(document).height() - $(window).height() - $(document).scrollTop() < 10) {
         
         if (!imagesLoading) {
             appendToMasonry();
         }
         
     }
     
});

针对第二个问题,我们需要首先在页面上放置所有的案例并隐藏,然后通过JavaScript进行随机排序后,添加到页面中。随机排序使用了JavaScript数组的sort方法,如下所示。

1
2
3
4
5
6
7
8
9
10
11
12
var  ghostNode = $( '#masonry_ghost' ).find( '.thumbnail' ), i, ghostIndexArray = [];
var  ghostCount = ghostNode.length;
for (i=0; i<ghostCount; i++){
     ghostIndexArray[i] = i;
}
ghostIndexArray.sort( function (a, b) {
     if (Math.random() > 0.5) {
         return  a - b;
     } else  {
         return  b - a;
     }
});

JavaScript数组的sort方法接受一个函数,在函数内部决定两个需要比较对象的大小,我么使用Math.random来生成一个0-1的随机数来和0.5比较,从而使得两个需要比较的对象大小也是随机的。

注:特别需要注意,由于隐藏在DIV中的图片还是会在页面打开时加载,我们需要先将 img 标签改为 input[type=hidden] 标签,并在需要的时候还原成 img 标签。也即是将 <img src="./images/2426.png" /> 替换为 <input type="hidden" value="2426.png"> 。

此时页面显示效果如下图所示(源代码在 index_3.html 中,文章最后会提供下载地址)。

注意,此时页面中典型案例的顺序已经是随机的了,并且当页面滚动条靠近底部时会自动加载剩余的列表。

Lightbox为页面增色

由于瀑布流展示的图片比较小,最后我们还需要Lightbox为页面增色,调用代码非常简单,只需要修改 img 标签即可。

< img  src = "./images/1408.png" >

修改为:

< a  href = "./images/large/1408.png"  data-lightbox = "lightbox_"  title = "Enterprise Solution  (by James)" >< img  src = "./images/1408.png" ></ a >

注:Lightbox和Bootstrap有点冲突,导致Lightbox不能正常显示弹出框中的图片,我们还需要在CSS中加入如下代码。

1
2
3
4
5
.lightbox .lb-image
{
     max-width : none ;
}

使用Lightbox后的效果(源代码在 index.html 中,文章最后会提供下载地址)。

此时,我们已经可以在全部的图片(是大图哦)中导航,效果很赞!

最终效果

快来体验一把: http://fineui.com/case/

全部源代码下载

下载地址: http://fineui.com/bbs/forum.php?mod=viewthread&tid=3606

小结

仔细想想,现在的Web前端工程师已经非常幸福了,你看IE6已死,IE7/8也蹦弹不了几天,还有那么多优秀的CSS、JavaScript框架供我们使用。而大部分时候我们的也没必要从头做起(做学习研究除外),站在巨人的肩膀上,省时省工,而且效果更好!

[置顶] 纯手工打造漂亮的瀑布流,五大插件一个都不少Bootstrap+jQuery+Masonry+imagesLoaded+Lightbox!的更多相关文章

  1. 纯手工打造漂亮的瀑布流,五大插件一个都不少Bootstrap+jQuery+Masonry+imagesLoaded+Lightbox!

    前两天写的文章<纯手工打造漂亮的垂直时间轴,使用最简单的HTML+CSS+JQUERY完成100个版本更新记录的华丽转身!>受到很多网友的喜爱,今天特别推出姊妹篇<纯手工打造漂亮的瀑 ...

  2. 瀑布流,五大插件一个都不少Bootstrap+jQuery+Masonry+imagesLoaded+Lightbox!

    纯手工打造漂亮的瀑布流,五大插件一个都不少Bootstrap+jQuery+Masonry+imagesLoaded+Lightbox!   前两天写的文章<纯手工打造漂亮的垂直时间轴,使用最简 ...

  3. [置顶] 纯手工打造漂亮的垂直时间轴,使用最简单的HTML+CSS+JQUERY完成100个版本更新记录的华丽转身!

    前言 FineUI控件库发展至今已经有 5 个年头,目前论坛注册的QQ会员 5000 多人,捐赠用户 500 多人(捐赠用户转化率达到10%以上,在国内开源领域相信这是一个梦幻数字!也足以证明Fine ...

  4. 纯手工打造漂亮的垂直时间轴,使用最简单的HTML+CSS+JQUERY完成100个版本更新记录的华丽转身!

    前言 FineUI控件库发展至今已经有 5 个年头,目前论坛注册的QQ会员 5000 多人,捐赠用户 500 多人(捐赠用户转化率达到10%以上,在国内开源领域相信这是一个梦幻数字!也足以证明Fine ...

  5. 纯手工打造简单分布式爬虫(Python)

    前言 这次分享的文章是我<Python爬虫开发与项目实战>基础篇 第七章的内容,关于如何手工打造简单分布式爬虫 (如果大家对这本书感兴趣的话,可以看一下 试读样章),下面是文章的具体内容. ...

  6. 纯 css column 布局实现瀑布流效果

    原理 CSS property: columns.CSS属性 columns 用来设置元素的列宽和列数. 兼容性 chrome 50+ IE 10+ android browser 2.1+ with ...

  7. 分享一个Vue实现图片水平瀑布流的插件

    这里给大家分享我在网上总结出来的一些知识,希望对大家有所帮助 一.需求来源 今天碰到了一个需求,需要在页面里,用水平瀑布流的方式,将一些图片进行加载,这让我突然想起我很久以前写的一篇文章<JS两 ...

  8. 纯手工打造(不使用IDE)java web 项目

    必备环境 1.编译器:jdk 2.web服务器:tomcat 3.文本编辑器:sublime,编写java文件和jsp文件,没有的话用记事本也行. 一.建立工程目录结构,如下图 在操作系统下完成即可, ...

  9. 纯手工打造dropdownlist控件

    先上图吧,看看效果. JS代码: ; (function ($) { var DropdownList = function (oDataSouce, oControlsContainer, oLis ...

随机推荐

  1. 重新想象 Windows 8 Store Apps (3) - 控件之内容控件: ToolTip, Frame, AppBar, ContentControl, ContentPresenter; 容器控件: Border, Viewbox, Popup

    原文:重新想象 Windows 8 Store Apps (3) - 控件之内容控件: ToolTip, Frame, AppBar, ContentControl, ContentPresenter ...

  2. [Windows Phone] 地图控制项的经纬度

    原文:[Windows Phone] 地图控制项的经纬度 前言 本文主要示范如何使用地图经纬度以及显示地标和行人街道,并透过卷轴控制地图缩放比例的功能. ? 实作 step1 建立专案. ? step ...

  3. 生活中的大数据 hadoop

    大数据和我有关吗?大数据就是大量的数据吗?只有互联网公司才有大数据吗?想盘活大数据必须买昂贵的软硬件吗?大数据怎么存储计算?大数据,这个时下最火热的互联网词语,你了解多少呢?

  4. WinForm 国际化开发一例

    1.新建一个WinForm程序(在中文版的Windows下),如下,添加1个Button和1个Label 设置Form1的localizable属性为True(Form1的properties里的De ...

  5. 【原创】leetCodeOj ---Remove Duplicates from Sorted List II 解题报告

    明日深圳行,心情紧张,写博文压压惊 囧 ------------------------------------- 原题地址: https://oj.leetcode.com/problems/rem ...

  6. easyui动力头 &amp;&amp; 动态加入tabs

    今天,在实现了业务时的,我们需要根据后台操作,以产生多个数据tab页,而且每一个tab页表格根据需要动态生成的标题数据. 返回后台数据格例如,下面的公式: 实现方法例如以下: //$("#c ...

  7. Akka FSM 源代码分析

    Akka FSM 源代码分析 萧猛 <simonxiao@qq.com> 啰嗦几句 有限状态机本身不是啥新奇东西,在GoF的设计模式一书中就有状态模式, 也给出了实现的建议.各种语言对状态 ...

  8. 原生javascript与jquery 的比较

    JavaScript的优点和缺点: 优点: 性能:由于JavaScript运行在客户端,节省了web服务器的请求时间和带宽 轻量级的脚本语言,比较容易学习 运行在用户机器上,运行结果和处理相对比较快. ...

  9. javascript有用小技巧—实现分栏显示

    记得给师哥师姐測试考试系统的时候,看到他们的考试页面能够实现隐藏左边的考生信息部分,当时认为好高大上.好人性化. 如今学了javascript,我也能实现这个功能了,以下来显摆一下. 1.页面设计: ...

  10. 【C语言探索之旅】 第二课:工欲善其事,必先利其器

    内容简介 1.课程大纲 2.第一部分第二课:工欲善其事,必先利其器 3.第一部分第三课预告:你的第一个程序 课程大纲 我们的课程分为四大部分,每一个部分结束后都会有练习题,并会公布答案.还会带大家用C ...