CSS3效果:animate实现点点点loading动画效果二

box-shadow实现的打点效果

简介

box-shadow理论上可以生成任意的图形效果,当然也就可以实现点点点的loading效果了。

实现原理

html代码,首先需要写如下html代码以及class类名:

 订单提交中<span class="dotting"></span>

css代码

.dotting {
    display: inline-block; min-width: 2px; min-height:
    box-shadow: 2px 0 currentColor,6px 0 currentColor,10px 0 currentColor; /* for IE9+,...,3个点 */
    animation: dot 4s infinite step-start both;  for IE10+,... 
    *zoom: expression(this.innerHTML = '...');   for IE7. 若无需兼容IE7,此行删除 */
}
.dotting:before { content: '...'; }  for IE8. 若无需兼容IE8,此行以及下一行删除*/
.dotting::before { ''; }  for IE9+ 覆盖 IE8 
:root .dotting { margin-right: 8px; } 

@keyframes dot {
    25% { box-shadow: none; }                                   0个点 
    50% { box-shadow: 2px 0 currentColor; }                     1个点 
    75% { 2个点 */ }
}

这里用到了currentColor这个关键字,IE9+浏览器支持,其可以让CSS生成的图形的颜色跟所处环境的color属性值一样,也就是跟文字颜色一样。

各浏览器实现的效果如图所示:

支持CSS3 animation动画的浏览器显示的就是打点动画效果;对于不支持的浏览器,IE7/IE8显示的是真实的字符...,IE9浏览器虽然也是CSS3生成,但是是静态的,没有动画效果;此乃渐进兼容。

不足之处

虽然几乎所有浏览器都有模有样,但是,从效果上讲,还是有瑕疵的,IE10+以及FireFox浏览器下的点的边缘有些虚(参见下截图),虽然CSS代码并没有设置盒阴影模糊。这种羽化现象可以让IE以及FireFox在大数值盒阴影时候效果更接近photoshop的阴影效果;但是,在小尺寸阴影时候,并不是我们想要的。

border + background实现的打点效果

实现原理

html代码

订单提交中 width: 10px;
    padding-right:
    border-left: 2px solid currentColor; border-right:   
    background-color: currentColor; background-clip: content-box;
    box-sizing: border-box; dot 4s infinite step-start both; IE7  IE8  ''; } margin-left: padding-left: 2px; }  IE9+ 
    25% { border-color: transparent; background-color: transparent; }           border-right-color: transparent; }     transparent; }                                   
}

说明:

  1. 同样是4秒动画,每秒钟显示1个点;
  2. IE7/IE8实现原理跟上面box-shadow方法一致,都是内容生成,如果无需兼容IE7/IE8,可以按照第一个例子CSS代码注释说明删除一些CSS;
  3. currentColor关键字可以让图形字符化,必不可少;
  4. 最大功臣是CSS3 background-clip属性,可以让IE9+浏览器下左右padding没有背景色,于是形成了等分打点效果。
  5. box-sizing是让现代浏览器和IE7/IE8占据宽度完全一样的功臣:IE7/IE8实际宽度是width+padding-right12像素,其他现代浏览器为width+margin-left也是12像素;
  6. 这里CSS代码主要用来展示原理,故没有显示-webkit-animation以及@-webkit-keyframes私有前缀,实际目前还是需要的;

参考地址:再说CSS3 animation实现点点点loading动画

https://github.com/tawian/text-spinners

 

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


HTML5和CSS3实现3D展示商品信息的代码
利用HTML5中的Canvas绘制笑脸的代码
Html5剪切板功能的实现
如何通过HTML5触摸事件实现移动端简易进度条
Html5移动端获奖无缝滚动动画实现
关于HTML5和CSS3实现机器猫的代码
HTML5使用DOM进行自定义控制
使用HTML5 Canvas绘制阴影效果的方法
使用PHP和HTML5 FormData实现无刷新文件上传
如何解决HTML5 虚拟键盘出现挡住输入框的问题
HTML5中div和section以及article的区别分析
html5和CSS 实现禁止IOS长按复制粘贴功能
html5 touch事件实现触屏页面上下滑动
canvas 模拟实现电子彩票刮刮乐的代码
HTML5 Plus 实现手机APP拍照或相册选择图片上传的功能
Android自定义环形LoadingView效果
HTML5 canvas绘制五角星的方法
html5使用html2canvas实现浏览器截图
使用Canvas处理图片的方法介绍
利用Canvas模仿百度贴吧客户端loading小球的方法