今天,我想与大家分享一些专门为网格布局的图像制作的很酷的 CSS 加载动画效果。您可以把这些效果用在你的作品集,博客或任何你想要的网页中。设置很简单。我们使用了下面这些工具库来实现这个效果:

  现在,让我们来看看一些实际的代码,这应该是大家最想知道的!

效果演示      源码下载

HTML 代码

其实 HTML 代码都是很简单的,复杂和创意的部分在 CSS。代码如下:

<div class="row">
<div class="large-12 columns main">
<ul class="small-block-grid-2 medium-block-grid-3 large-block-grid-3 masonry">
<li class="masonry-item"><a target="_blank" href="#"><img src="data:images/01.jpg" alt="" /></a></li>
<li class="masonry-item"><a target="_blank" href="#"><img src="data:images/02.jpg" alt="" /></a></li>
<li class="masonry-item"><a target="_blank" href="#"><img src="data:images/03.jpg" alt="" /></a></li>
<li class="masonry-item"><a target="_blank" href="#"><img src="data:images/04.jpg" alt="" /></a></li>
<li class="masonry-item"><a target="_blank" href="#/"><img src="data:images/05.jpg" alt="" /></a></li>
<li class="masonry-item"><a target="_blank" href="#"><img src="data:images/06.jpg" alt="" /></a></li>
<li class="masonry-item"><a target="_blank" href="#"><img src="data:images/07.jpg" alt="" /></a></li>
<li class="masonry-item"><a target="_blank" href="#"><img src="data:images/08.jpg" alt="" /></a></li>
<li class="masonry-item"><a target="_blank" href="#"><img src="data:images/09.jpg" alt="" /></a></li>
<li class="masonry-item"><a target="_blank" href="#"><img src="data:images/10.jpg" alt="" /></a></li>
<li class="masonry-item"><a target="_blank" href="#"><img src="data:images/11.jpg" alt="" /></a></li>
<li class="masonry-item"><a target="_blank" href="#"><img src="data:images/12.jpg" alt="" /></a></li>
<li class="masonry-item"><a target="_blank" href="#/"><img src="data:images/13.jpg" alt="" /></a></li>
<li class="masonry-item"><a target="_blank" href="#"><img src="data:images/14.jpg" alt="" /></a></li>
<li class="masonry-item"><a target="_blank" href="#"><img src="data:images/15.jpg" alt="" /></a></li>
</ul> <ul class="pagination">
<li><a class="next" href="index-02.php">Next Page</a></li>
</ul> <div class="loading"></div>
</div><!-- End .main -->
</div><!-- End .row -->

CSS 代码

CSS 部分主要是动画效果,我们以 tada 效果为例:

@keyframes tada
{
0%
{
-webkit-transform: scale(1);
-moz-transform: scale(1);
-ms-transform: scale(1);
-o-transform: scale(1);
transform: scale(1);
} 10%,
20%
{
-webkit-transform: scale(.8) rotate(-2deg);
-moz-transform: scale(.8) rotate(-2deg);
-ms-transform: scale(.8) rotate(-2deg);
-o-transform: scale(.8) rotate(-2deg);
transform: scale(.8) rotate(-2deg);
} 30%,
50%,
70%,
90%
{
-webkit-transform: scale(1.04) rotate(2deg);
-moz-transform: scale(1.04) rotate(2deg);
-ms-transform: scale(1.04) rotate(2deg);
-o-transform: scale(1.04) rotate(2deg);
transform: scale(1.04) rotate(2deg);
} 40%,
60%,
80%
{
-webkit-transform: scale(1.04) rotate(-2deg);
-moz-transform: scale(1.04) rotate(-2deg);
-ms-transform: scale(1.04) rotate(-2deg);
-o-transform: scale(1.04) rotate(-2deg);
transform: scale(1.04) rotate(-2deg);
} 100%
{
-webkit-transform: scale(1) rotate(0);
-moz-transform: scale(1) rotate(0);
-ms-transform: scale(1) rotate(0);
-o-transform: scale(1) rotate(0);
transform: scale(1) rotate(0);
}
} .tada
{
-webkit-animation-name: tada;
-moz-animation-name: tada;
animation-name: tada;
}

jQuery

当图像被加载进来后,我们给图像添加上 CSS 效果,然后我们找到并显示该项目,最后会刷新 Masonry 布局。当用户滚动页面的时候,无限滚动插件将装载更多的图像并重复前面的步骤。代码如下:

jQuery(document)
.ready(function($) {
// Replace "tada" with an effect from the "effects.css" file.
var effect = 'animate tada'; var masonry_selector = '.masonry'; var masonry_item_selector = '.masonry-item'; // Initialize Masonry.
var $masonry = $(masonry_selector)
.masonry({
itemSelector: masonry_item_selector
}); // Find and hide the items.
var $masonry_items = $masonry
.find(masonry_item_selector)
.hide(); // Wait for the images to load.
$masonry
.imagesLoaded()
// An image has been loaded.
.progress(function(instance, image) {
// Add the effect.
var $image = $(image.img)
.addClass(effect); // Find and show the item.
var $item = $image
.parents(masonry_item_selector)
.show(); // Lay out Masonry.
$masonry
.masonry();
}); // Load more items.
$masonry
.infinitescroll({
navSelector: '.pagination',
nextSelector: '.pagination .next',
itemSelector: masonry_item_selector,
loading: {
finishedMsg: 'No more pages to load.',
img: 'images/loader.gif',
msgText: 'Loading the next page.',
selector: '.loading'
}
}, function(items, data, url) {
var $items = $(items)
.hide()
.imagesLoaded()
.progress(function(instance, image) {
var $image = $(image.img)
.addClass(effect); var $item = $image
.parents(masonry_item_selector)
.addClass('infinite-scroll-item')
.show(); $masonry
.masonry('appended', $item);
});
});
});

  

您可能感兴趣的相关文章

本文链接:为网格布局图片打造的超炫 CSS 加载动画效果

编译来源:梦想天空 ◆ 关注前端开发技术 ◆ 分享网页设计资源

为网格布局图片打造的超炫 CSS 加载动画的更多相关文章

  1. android 新闻应用、Xposed模块、酷炫的加载动画、下载模块、九宫格控件等源码

    Android精选源码 灵活的ShadowView,可替代CardView使用 基于Tesseract-OCR实现自动扫描识别手机号 Android播放界面仿QQ音乐开源音乐播放器 新闻应用项目采用了 ...

  2. 纯CSS3打造非常炫的加载动画

    纯css3打造的一款非常炫的加载图.用在需要一定时间加载的地方非常合适.先上效果图: 点击这里在线预览 代码非常简单.没有用任何javascript代码.纯css3实现. html代码: <di ...

  3. 炫!一组单元素实现的 CSS 加载进度提示效果

    之前的文章个大家分享过各种类型的加载效果(Loading Effects),这里再给大家奉献一组基于单个元素实现的 CSS 加载动画集合.这些加载效果都是基于一个 DIV 元素实现的,十分强悍. 温馨 ...

  4. 【Web前沿技术】纯 CSS3 打造的10个精美加载进度条动画

    之前向大家介绍8款优秀的 jQuery 加载动画和进度条插件,今天这篇文章向大家推荐10个纯 CSS3 代码实现精美加载进度条动画效果的方案.加载动画和进度条在网站和 Web 应用中的使用非常流行,特 ...

  5. 几行css3代码实现超炫加载动画

    之前为大家分享了css3实现的加载动画.今天为大家带来一款只需几行代码就可以实现超炫的动画加载特效.我们一起看下效果图: 在线预览   源码下载 实现代码: 极简的html代码: <div> ...

  6. 我用 CSS3 实现了一个超炫的 3D 加载动画

    今天给大家带来一个非常炫酷的CSS3加载Loading动画,它的特别之处在于,整个Loading动画呈现出了3D的视觉效果.这个Loading加载动画由12个3D圆柱体围成一个椭圆形,同时这12个圆柱 ...

  7. 超酷jQuery进度条加载动画集合

    在丰富多彩的网页世界中,进度条加载动画的形式非常多样,有利用gif图片实现的loading动画,也有利用jQuery和CSS3实现的进度加载动画,本文主要向大家介绍很多jQuery和CSS3实现的进度 ...

  8. iOS开发——图形编程Swift篇&CAShapeLayer实现圆形图片加载动画

    CAShapeLayer实现圆形图片加载动画 几个星期之前,Michael Villar在Motion试验中创建一个非常有趣的加载动画. 下面的GIF图片展示这个加载动画,它将一个圆形进度指示器和圆形 ...

  9. 使用CAShapeLayer来实现圆形图片加载动画[译]

    原文链接 : How To Implement A Circular Image Loader Animation with CAShapeLayer 原文作者 : Rounak Jain 译文出自 ...

随机推荐

  1. 【原创】--linux平台下opencv安装

    1.到opencv官网下载源码 也可以下载此链接http://pan.baidu.com/s/1mgId5ZM 2.解压到任意目录 可以使用右键-提取到此处,也可以在命令行中使用指令解压(linux中 ...

  2. [转]Oracle VM VirtualBox虚拟机,Ubuntu虚拟机共享文件夹

    VirtualBox的菜单里选择"设备" -> "安装增强功能...". "设备" -> "共享文档夹",添 ...

  3. WPF快速入门系列(8)——MVVM快速入门

    一.引言 在前面介绍了WPF一些核心的内容,其中包括WPF布局.依赖属性.路由事件.绑定.命令.资源样式和模板.然而,在WPF还衍生出了一种很好的编程框架,即WVVM,在Web端开发有MVC,在WPF ...

  4. XXX项目总结

    前言 昨天晚上睡不着总感觉有些什么东西需要记下来,所以就有了这篇文章.做了好几次的重构是应该有一个总结以备以后查阅,当然有些设计思想是通过自己的总结也有些是吸收别人的思想,同样如果能对你有所帮助那就再 ...

  5. google map javascript api v3 例子

    之前一直用百度map,但如果是国外的项目就需要用google地图.由于在国内屏蔽了google地图的服务,因此调用的是一个国内地址(开发用).这个地址没有用key,语言设置也还是中文的. //---- ...

  6. 图解集合3:CopyOnWriteArrayList

    初识CopyOnWriteArrayList 第一次见到CopyOnWriteArrayList,是在研究JDBC的时候,每一个数据库的Driver都是维护在一个CopyOnWriteArrayLis ...

  7. MySQL3:索引

    什么是索引 索引是对数据库表中一列或者多列的值进行排序的一种结构,所引用于快速找出在某个列中有一特定值的行.不使用索引,MySQL必须从第一条记录开始读完整个表,直到找出相关的行.表越大,查询数据所花 ...

  8. Java设计模式7:适配器模式

    适配器模式 适配器模式说的是,可以把一个类的接口变换成客户端所期待的另一种接口,使得原本因接口不匹配而无法在一起工作的两个类可以一起工作. 适配器模式的用途 适配器模式的用途,在网上找了一幅图,挺形象 ...

  9. java提高篇(十六)-----异常(一)

         Java的基本理念是“结构不佳的代码不能运行”!!!!! 大成若缺,其用不弊. 大盈若冲,其用不穷. 在这个世界不可能存在完美的东西,不管完美的思维有多么缜密,细心,我们都不可能考虑所有的因 ...

  10. AngularJS快速入门指南16:Bootstrap

    thead>tr>th, table.reference>tbody>tr>th, table.reference>tfoot>tr>th, table ...