CSS3实现loading图

HTML5学堂:学习CSS3,重要的并不是那几个命令,而是如何应用CSS3的知识实现网站中的效果,换句话说,“只有想不到,没有做不到”。在这个效果当中,主要用到了圆角边框和动画。

HTML5学堂-刘国利在此郑重声明:本篇文章的灵感来源于2014年的自己一个学生的技术演讲,他运用CSS3实现了loading图效果,在此书写出来与大家分享。效果创造的原作者——黄仕辉

实现的基本思路:利用圆角边框对loading图的样式控制,让其从方形变化为圆形;之后控制不同的边框粗细,调整更佳的视觉效果;最后利用CSS3中的动画,实现运动;在进行布局的时候,要考虑移动端水平垂直居中的要求以及不同分辨率状态下的效果。

基本效果图

基本html结构搭建

<!doctype html>
<html>
<head>
 <meta charset="UTF-8">
 <title>HTML5学堂 - CSS3 - loading图</title>
 <link rel="stylesheet" href="../common/reset.css">
 <style>
     body,html {
         height: 100%;
     }
     .wrap{
         position: absolute;
         top: 0%;
         right: 0%;
         bottom: 0%;
         left: 0%;
         width: 0px;
         height: 0px;
         padding: 15%;
         margin: auto;
         border: 1px solid #06f;
         border-left-width: 4px;
         border-bottom-width: 3px;
         border-right-width: 2px;
         border-radius: 50%;
     }
 </style>
</head>
<body>
 <div class="wrap"></div>
</body>
</html>

此处采用了一种很特殊的居中方法,将盒模型进行定位处理之后,上下左右均采用了0%的值,然后运用margin:auto的控制,让上下左右自动处理外边距值,从而达到居中的状态。关于元素的水平垂直居中,可点击查看:《网易NEC水平垂直居中》

另一个处理,是宽度高度自适应的设置,在为width和height设置百分比之后,会分别根据父级元素的宽度和高度进行计算,此时一旦设备宽度高度不同,我们的loading图就不再是正圆形,由于padding设置百分比值时,均是按照文字方向计算的(默认都是参照父级的宽度计算),因此此处我们将宽高均设为0,而用padding进行内容区大小的设置。

关于边框的设置已经提到了,四个方向采用不同的边框粗细。

顺便一提,由于使用的是CSS3进行控制,因此,即便是在PC端调整窗口大小,loading图的大小也会随之发生变化。

显示效果

PS:从自己博客(独行冰海)取的图片,所以自然底部就有水印了~~~

CSS3动画设置

之后进行CSS3动画的设置即可,在CSS中代码中增加如下内容:

.wrap{

 -webkit-animation: loading 2s linear infinite;
}

@-webkit-keyframes loading {
 from {-webkit-transform: rotate(0deg);}
 to {-webkit-transform: rotate(360deg);}
}

当前就已经实现出来了,不过,在测试的时候会发现,出现了滚动条,因此,我们可以给body再增加这样一句代码:

body {
 overflow: hidden;
}

CSS3就已经搞定了~很简单的解决了loading的效果,很适合在移动端应用。

原文发布于微信公众号 - HTML5学堂(h5course-com)

原文发表时间:2015-12-24

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏菜鸟前端工程师

JavaScript学习笔记024-默认行为0滚轮事件

912
来自专栏前端说吧

css布局 - 垂直居中布局的一百种实现方式(更新中...)

1. line-height行高简单粗暴实现法:line-height:Npx(N = 与元素高度相同的值)

3611
来自专栏前端小叙

css如何实现一个元素高度固定宽度按比例显示?

用padding-top百分比可以实现宽度固定高度按比例展示,现在的需求是对一个video视频的盒子div高度是固定的,宽度如何按比例展示?

1381
来自专栏Coco的专栏

滚动视差?CSS 不在话下

视差滚动(Parallax Scrolling)是指让多层背景以不同的速度移动,形成立体的运动效果,带来非常出色的视觉体验。 作为网页设计的热点趋势,越来越多的...

3577
来自专栏淡定的博客

html5之自定义视频播放器

5792
来自专栏用户画像

H5新增的块级的语义元素

figure元素表示一段独立的流内容,一般表示文档主体流内容的一个独立单元。使用<figcaption>元素为figure元素组添加标题。

572
来自专栏HTML5学堂

HTML5视音频-解决全屏下出现的控制栏

HTML5学堂:HTML5视音频-解决全屏下的控制栏。HTML5可以简简单单的实现视频、音频的播放功能,功能虽好用,但是它的默认样式有点淡淡的忧伤,问题虽存在,...

3366
来自专栏编程之旅

iOS开发 ——全机型适配思路

最近一直在研究学习ReactiveCocoa,并且在给项目转型到MVVM模式打基础,所以博客也很久没有更新了。

1602
来自专栏LIN_ZONE

7款让人惊叹的HTML5粒子动画特效(转载)

这是一款利用HTML5 Canvas模拟出来的30000个粒子动画,当你用鼠标在canvas画布上移动时,鼠标周围的一些粒子就会跟着你移动,并形成一定的图案,就...

5752
来自专栏HTML5学堂

CSS3-3D相关知识详解—视角以及变形方向

CSS3-3D相关知识详解—视角以及变形方向 HTML5学堂:视角以及变形方向。HTML5中非常不错的一个变革,便是将特效从二维平面上的变化,推进到了三维立体当...

2894

扫码关注云+社区