侯体宗的博客
  • 首页
  • Hyperf版
  • beego仿版
  • 人生(杂谈)
  • 技术
  • 关于我
  • 更多分类
    • 文件下载
    • 文字修仙
    • 中国象棋ai
    • 群聊
    • 九宫格抽奖
    • 拼图
    • 消消乐
    • 相册

CSS3实现时间轴效果

前端  /  管理员 发布于 7年前   155

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

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

大概效果就是这样啦,下来废话不说,还是直接进入主题:
 
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-align: center;   
  6.                 color:#fff;   
  7.             }   
  8.             .timezone{   
  9.                 width:6px;   
  10.                 height: 350px;   
  11.                 background: lightblue;   
  12.                 margin: 0 auto;   
  13.                 margin-top:50px;   
  14.                 border-radius: 3px;   
  15.                 position: relative;   
  16.                 -webkit-animation: heightSlide 2s linear;   
  17.             }   
  18.             @-webkit-keyframes heightSlide{   
  19.                 0%{   
  20.                     height: 0;   
  21.                 }   
  22.                 100%{   
  23.                     height: 350px;   
  24.                 }   
  25.             }   
  26.             .timezone:after{   
  27.                 content: '未完待续...';   
  28.                 width: 100px;   
  29.                 color:#fff;   
  30.                 position: absolute;   
  31.                 margin-left: -35px;   
  32.                 bottombottom: -30px;   
  33.                 -webkit-animation: showIn 4s ease;   
  34.             }   
  35.             .timezone .time,.timezone .timeLeft{   
  36.                 position: absolute;   
  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.                 position: absolute;   
  69.                 margin-left: -120px;   
  70.                 margin-top: 3px;   
  71.                 color:#eee;   
  72.                 font-size: 14px;   
  73.                 cursor:pointer;   
  74.                 -webkit-animation: showIn 3s ease;   
  75.             }   
  76.             .timezone .timeLeft h2{   
  77.                 margin-left: 60px;   
  78.                 width: 100px;   
  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.                 position: absolute;   
  87.                 top:50%;   
  88.                 margin-top: -25px;   
  89.                 left:50px;   
  90.                 width: 300px;   
  91.                 height: 50px;   
  92.                 background: lightblue;   
  93.                 border:3px solid #eee;   
  94.                 border-radius: 10px;   
  95.                 z-index: 2;   
  96.                 overflow: hidden;   
  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.                 height: 170px;   
  106.             }   
  107.             .timezone .time div p,.timezone .timeLeft div p{   
  108.                 color: #fff;   
  109.                 font-weight: bold;   
  110.                 text-align: center;   
  111.             }   
  112.             .timezone .time:before,.timezone .timeLeft:before{   
  113.                 content: '';   
  114.                 position: absolute;   
  115.                 top:0px;   
  116.                 left: 32px;   
  117.                 width: 0px;   
  118.                 height: 0px;   
  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-style: none;   
  131.                 width:300px;   
  132.                 padding:5px 0 0;   

  • 上一条:
    纯css实现三角的简单实例
    下一条:
    CSS3实现10种Loading效果
  • 昵称:

    邮箱:

    0条评论 (评论内容有缓存机制,请悉知!)
    最新最热
    • 分类目录
    • 人生(杂谈)
    • 技术
    • linux
    • Java
    • php
    • 框架(架构)
    • 前端
    • ThinkPHP
    • 数据库
    • 微信(小程序)
    • Laravel
    • Redis
    • Docker
    • Go
    • swoole
    • Windows
    • Python
    • 苹果(mac/ios)
    • 相关文章
    • 使用 Alpine.js 排序插件对元素进行排序(0个评论)
    • 在js中使用jszip + file-saver实现批量下载OSS文件功能示例(0个评论)
    • 在vue中实现父页面按钮显示子组件中的el-dialog效果(0个评论)
    • 使用mock-server实现模拟接口对接流程步骤(0个评论)
    • vue项目打包程序实现把项目打包成一个exe可执行程序(0个评论)
    • 近期文章
    • 智能合约Solidity学习CryptoZombie第三课:组建僵尸军队(高级Solidity理论)(0个评论)
    • 智能合约Solidity学习CryptoZombie第二课:让你的僵尸猎食(0个评论)
    • 智能合约Solidity学习CryptoZombie第一课:生成一只你的僵尸(0个评论)
    • 在go中实现一个常用的先进先出的缓存淘汰算法示例代码(0个评论)
    • 在go+gin中使用"github.com/skip2/go-qrcode"实现url转二维码功能(0个评论)
    • 在go语言中使用api.geonames.org接口实现根据国际邮政编码获取地址信息功能(1个评论)
    • 在go语言中使用github.com/signintech/gopdf实现生成pdf分页文件功能(0个评论)
    • gmail发邮件报错:534 5.7.9 Application-specific password required...解决方案(0个评论)
    • 欧盟关于强迫劳动的规定的官方举报渠道及官方举报网站(0个评论)
    • 在go语言中使用github.com/signintech/gopdf实现生成pdf文件功能(0个评论)
    • 近期评论
    • 122 在

      学历:一种延缓就业设计,生活需求下的权衡之选中评论 工作几年后,报名考研了,到现在还没认真学习备考,迷茫中。作为一名北漂互联网打工人..
    • 123 在

      Clash for Windows作者删库跑路了,github已404中评论 按理说只要你在国内,所有的流量进出都在监控范围内,不管你怎么隐藏也没用,想搞你分..
    • 原梓番博客 在

      在Laravel框架中使用模型Model分表最简单的方法中评论 好久好久都没看友情链接申请了,今天刚看,已经添加。..
    • 博主 在

      佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 @1111老铁这个不行了,可以看看近期评论的其他文章..
    • 1111 在

      佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 网站不能打开,博主百忙中能否发个APP下载链接,佛跳墙或极光..
    • 2016-10
    • 2016-11
    • 2017-06
    • 2017-07
    • 2017-08
    • 2017-09
    • 2017-10
    • 2017-11
    • 2018-03
    • 2018-04
    • 2018-05
    • 2018-06
    • 2018-09
    • 2018-11
    • 2018-12
    • 2019-02
    • 2020-03
    • 2020-04
    • 2020-05
    • 2020-06
    • 2021-04
    • 2021-05
    • 2021-07
    • 2021-08
    • 2021-09
    • 2021-10
    • 2021-11
    • 2022-08
    • 2022-09
    • 2022-10
    • 2022-11
    • 2022-12
    • 2023-01
    • 2023-02
    • 2023-03
    • 2023-04
    • 2023-05
    • 2023-06
    • 2023-07
    • 2023-09
    • 2023-10
    • 2023-11
    • 2023-12
    • 2024-01
    • 2024-02
    • 2024-03
    • 2024-04
    Top

    Copyright·© 2019 侯体宗版权所有· 粤ICP备20027696号 PHP交流群

    侯体宗的博客