CSS3实现时间轴效果


Posted in HTML / CSS onJuly 11, 2016

最近打开电脑就能看到极客学院什么新用户vip免费一个月,就进去看看咯,这里就不说它的课程怎么滴了,里面实战路径图页面看到了这个效果: 

CSS3实现时间轴效果

有点像时间轴的赶脚,而且每一块鼠标悬浮上去也有下拉效果展开介绍截图信息,就感觉效果还不错。但感觉这种效果貌似对于动态添加不是很灵活,因为高度不像宽度可以灵活的自适应,故添加得自己一个一个设置。所以很多都是做成展示效果。
 
当然啦,自己也基于它的这个想法搞了一点简单点的类似效果,主要还是整个布局效果,具体每一块内容就不仿造了,而且我自己也加了一下开场动画,让它更好玩一些…
 
先来看看效果吧: 

CSS3实现时间轴效果

大概效果就是这样啦,下来废话不说,还是直接进入主题:
 
HTML结构:

XML/HTML Code复制内容到剪贴板
  1. <div class="timezone">  
  2.             <div class="time">  
  3.                 <h2>2015-07-02</h2>  
  4.                 <div>  
  5.                     <p>暴走大事件第一季</p>  
  6.                     <ul>  
  7.   
  8.                     </ul>  
  9.                 </div>  
  10.             </div>  
  11.             <div class="timeLeft" style="top: 100px;">  
  12.                 <h2>2015-07-02</h2>  
  13.                 <div>  
  14.                     <p>暴走大事件第二季</p>  
  15.                     <ul>  
  16.   
  17.                     </ul>  
  18.                 </div>  
  19. </div>    
  20.   

这里简化了一下HTML结构,.time类表示在右边,.timeLeft表示在左边,然后加点上外边距就可以了,每一块里面的内容我就删减掉了。
 
CSS样式代码如下:

CSS Code复制内容到剪贴板
  1. body{   
  2.                 background#333;   
  3.             }   
  4.             h1{   
  5.                 text-aligncenter;   
  6.                 color:#fff;   
  7.             }   
  8.             .timezone{   
  9.                 width:6px;   
  10.                 height350px;   
  11.                 background: lightblue;   
  12.                 margin: 0 auto;   
  13.                 margin-top:50px;   
  14.                 border-radius: 3px;   
  15.                 positionrelative;   
  16.                 -webkit-animation: heightSlide 2s linear;   
  17.             }   
  18.             @-webkit-keyframes heightSlide{   
  19.                 0%{   
  20.                     height: 0;   
  21.                 }   
  22.                 100%{   
  23.                     height350px;   
  24.                 }   
  25.             }   
  26.             .timezone:after{   
  27.                 content'未完待续...';   
  28.                 width100px;   
  29.                 color:#fff;   
  30.                 positionabsolute;   
  31.                 margin-left: -35px;   
  32.                 bottombottom: -30px;   
  33.                 -webkit-animation: showIn 4s ease;   
  34.             }   
  35.             .timezone .time,.timezone .timeLeft{   
  36.                 positionabsolute;   
  37.                 margin-left: -10px;   
  38.                 margin-top:-10px;   
  39.                 width:20px;   
  40.                 height:20px;   
  41.                 border-radius: 50%;   
  42.                 border:4px solid rgba(255,255,255,0.5);   
  43.                 background: lightblue;   
  44.                 -webkit-transition: all 0.5s;   
  45.                 -webkit-animation: showIn ease;   
  46.             }   
  47.             .timezone .time:nth-child(1){   
  48.                 -webkit-animation-duration:1s;   
  49.             }   
  50.             .timezone .timeLeft:nth-child(2){   
  51.                 -webkit-animation-duration:1.5s;   
  52.             }   
  53.             .timezone .time:nth-child(3){   
  54.                 -webkit-animation-duration:2s;   
  55.             }   
  56.             .timezone .timeLeft:nth-child(4){   
  57.                 -webkit-animation-duration:2.5s;   
  58.             }   
  59.             @-webkit-keyframes showIn{   
  60.                 0%,70%{   
  61.                     opacity: 0;   
  62.                 }   
  63.                 100%{   
  64.                     opacity: 1;   
  65.                 }   
  66.             }   
  67.             .timezone .time h2,.timezone .timeLeft h2{   
  68.                 positionabsolute;   
  69.                 margin-left: -120px;   
  70.                 margin-top3px;   
  71.                 color:#eee;   
  72.                 font-size14px;   
  73.                 cursor:pointer;   
  74.                 -webkit-animation: showIn 3s ease;   
  75.             }   
  76.             .timezone .timeLeft h2{   
  77.                 margin-left60px;   
  78.                 width100px;   
  79.             }   
  80.             .timezone .time:hover,.timezone .timeLeft:hover{   
  81.                 border:4px solid lightblue;   
  82.                 background: lemonchiffon;   
  83.                 box-shadow: 0 0 2px 2px rgba(255,255,255,0.4);   
  84.             }   
  85.             .timezone .time div,.timezone .timeLeft div{   
  86.                 positionabsolute;   
  87.                 top:50%;   
  88.                 margin-top: -25px;   
  89.                 left:50px;   
  90.                 width300px;   
  91.                 height50px;   
  92.                 background: lightblue;   
  93.                 border:3px solid #eee;   
  94.                 border-radius: 10px;   
  95.                 z-index: 2;   
  96.                 overflowhidden;   
  97.                 cursor:pointer;   
  98.                 -webkit-animation: showIn 3s ease;   
  99.                 -webkit-transition: all 0.5s;   
  100.             }   
  101.             .timezone .timeLeft div{   
  102.                 left:-337px;   
  103.             }   
  104.             .timezone .time div:hover,.timezone .timeLeft div:hover{   
  105.                 height170px;   
  106.             }   
  107.             .timezone .time div p,.timezone .timeLeft div p{   
  108.                 color#fff;   
  109.                 font-weightbold;   
  110.                 text-aligncenter;   
  111.             }   
  112.             .timezone .time:before,.timezone .timeLeft:before{   
  113.                 content'';   
  114.                 positionabsolute;   
  115.                 top:0px;   
  116.                 left32px;   
  117.                 width0px;   
  118.                 height0px;   
  119.                 border:10px solid transparent;   
  120.                 border-right:10px solid #eee;   
  121.                 z-index:-1;   
  122.                 -webkit-animation: showIn 3s ease;   
  123.             }   
  124.             .timezone .timeLeft:before{   
  125.                 left:-33px;   
  126.                 border:10px solid transparent;   
  127.                 border-left:10px solid #eee;   
  128.             }   
  129.             .timezone .time div ul,.timezone .timeLeft div ul{   
  130.                 list-stylenone;   
  131.                 width:300px;   
  132.                 padding:5px 0 0;   
  133.                 border-top:2px solid #eee;   
  134.                 color:#fff;   
  135.                 text-aligncenter;   
  136.             }   
  137.             .timezone .time div li,.timezone .timeLeft div li{   
  138.                 displayinline-block;   
  139.                 height25px;   
  140.                 line-height25px;   
  141.             }    
  142.   

此CSS样式代码仅供参考,实用性不是很强,而且同样没有怎么整理过,主要还是理解一下动画效果还有整体布局吧。祝好!

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

原文链接:http://www.cnblogs.com/jr1993/p/4626815.html

HTML / CSS 相关文章推荐
基于css3仿造window7的开始菜单
Jun 17 HTML / CSS
前端canvas动画如何转成mp4视频的方法
Jun 17 HTML / CSS
HTML5安全介绍之内容安全策略(CSP)简介
Jul 10 HTML / CSS
突袭HTML5之Javascript API扩展2—地理信息服务及地理位置API学习
Jan 31 HTML / CSS
HTML5 预加载让页面得以快速呈现
Aug 13 HTML / CSS
HTML5移动端手机网站开发流程
Apr 25 HTML / CSS
html5中的一些标签学习(心得)
Oct 18 HTML / CSS
HTML5微信播放全屏问题的解决方法
Mar 09 HTML / CSS
HTML5中input[type='date']自定义样式与日历校验功能的实现代码
Jul 11 HTML / CSS
基于HTML5 WebGL的3D机房的示例
Mar 16 HTML / CSS
Html5嵌入钉钉的实现示例
Jun 04 HTML / CSS
详解CSS3.0(Cascading Style Sheet) 层叠级联样式表
Jul 16 HTML / CSS
CSS3实现10种Loading效果
Jul 11 #HTML / CSS
CSS3实现可爱的小黄人动画
Jul 11 #HTML / CSS
使用CSS3滤镜的filter:blur属性制作毛玻璃模糊效果的方法
Jul 08 #HTML / CSS
分享CSS3制作卡片式图片的方法
Jul 08 #HTML / CSS
CSS3制作缩略图的详细过程
Jul 08 #HTML / CSS
CSS3制作圆角图片和椭圆形图片
Jul 08 #HTML / CSS
css3media响应式布局实例
Jul 08 #HTML / CSS
You might like
PHP分页类集锦
2014/11/18 PHP
ThinkPHP设置禁止百度等搜索引擎转码(简单实用)
2016/02/15 PHP
PHP针对多用户实现更换头像功能
2016/09/04 PHP
PHP模拟http请求的方法详解
2016/11/09 PHP
一个对于js this关键字的问题
2007/01/09 Javascript
jQuery实现的立体文字渐变效果
2010/05/17 Javascript
js获取TreeView控件选中节点的Text和Value值的方法
2012/11/24 Javascript
jquery.post用法关于type设置问题补充
2014/01/03 Javascript
js数组循环遍历数组内所有元素的方法
2014/01/18 Javascript
js中将String转换为number以便比较
2014/07/08 Javascript
基于socket.io+express实现多房间聊天
2016/03/17 Javascript
浅谈Javascript中的函数、this以及原型
2016/10/09 Javascript
浅析BootStrap Treeview的简单使用
2016/10/12 Javascript
json2.js 入门教程之使用方法与实例分析
2017/09/14 Javascript
浅析为什么a=&quot;abc&quot; 不等于 a=new String(&quot;abc&quot;)
2017/10/25 Javascript
利用10行js代码实现上下滚动公告效果
2017/12/08 Javascript
使用ajax的post同步执行(实现方法)
2017/12/21 Javascript
在Mac下彻底卸载node和npm的方法
2018/05/16 Javascript
React倒计时功能实现代码——解耦通用
2020/09/18 Javascript
python列表与元组详解实例
2013/11/01 Python
vc6编写python扩展的方法分享
2014/01/17 Python
Python 多线程实例详解
2017/03/25 Python
python实现对指定输入的字符串逆序输出的6种方法
2018/04/26 Python
Python基础之循环语句用法示例【for、while循环】
2019/03/23 Python
python中通过selenium简单操作及元素定位知识点总结
2019/09/10 Python
全网最细 Python 格式化输出用法讲解(推荐)
2021/01/18 Python
解决pycharm不能自动保存在远程linux中的问题
2021/02/06 Python
45个非常奇妙的CSS3 特性应用示例
2012/01/01 HTML / CSS
YOOX台湾:意大利奢侈品电商
2018/10/13 全球购物
美国环保妈妈、儿童和婴儿用品购物网站:The Tot
2019/11/24 全球购物
银行实习人员自我鉴定
2013/09/22 职场文书
客户经理岗位职责
2013/12/08 职场文书
问卷调查计划书
2014/01/10 职场文书
大学生自我评价范文
2015/03/03 职场文书
windows11怎么查看自己安装的版本号? win11版本号的查看方法
2021/11/21 数码科技
HTML5中的DOCUMENT.VISIBILITYSTATE属性详解
2023/05/07 HTML / CSS