纯css实现的自适应的垂直时间线

互联网用户喜欢使信息更容易消化的图形。垂直时间线可以讲述你公司的故事及其发展历程。它可以揭示产品或服务的演变,讨论特定行业的历史,甚至可以引导你的客户完成你提供服务的过程。最重要的是,你可以使用一点 CSS 就能在自己的网站上创建垂直时间线。

本文介绍的是一个可以自适应的垂直时间线。

时间线

从 HTML 开始

你的网页上的 HTML 标记为你的时间线提供内容,下面是示例代码:

<!-- main timeline section -->
<section id="cd-timeline" class="cd-container cssanimations">
  <!-- single timeline event -->
  <div class="cd-timeline-block">
    <div class="cd-timeline-img cd-picture">
      <img src="event-calender.png" />
    </div>
    <div class="cd-timeline-content">
      <h2>Event 1</h2>
      <p>Event 1 Description </p>
      <span class="cd-date">Sunday, 19 June 2016</span>
    </div>
  </div>
  ....
  ....
</section>

上面的示例是时间线上的单个事件,你只需通过在代码的第 3 行和第 8 行之间复制,相应地修改它们并将它们粘贴到第 8 行和第 9 行之间来插入附加事件,为你想要添加到时间线的尽可能多的事件执行此操作。

设计你的时间线

你可以使用标准 HTML 标记来设置时间线的样式,但这非常耗时且相当多余。最好改用 CSS 样式。下面是一些基本 CSS 样式的示例代码;你必须使用单独的代码来设置各个元素的样式:

#cd-timeline {
  position: relative;
  padding: 2em 0;
  margin-top: 2em;
  margin-bottom: 2em;
}
#cd-timeline::before {
  /* this is the vertical line */
  content: '';
  position: absolute;
  top: 0;
  height: 100%;
  width: 4px;
  background: #d7e4ed;
  left: 50%;
  margin-left: -2px;
}
.cd-container::after {
  content: '';
  display: table;
  clear: both;
}
.cd-container {
  width: 90%;
  max-width: 1170px;
  margin: 0 auto;
}
.cd-timeline-block:first-child {
  margin-top: 0;
}
.cd-timeline-block {
  position: relative;
      margin: 4em 0;
}
.cd-timeline-content {
  margin-left: 0;
  padding: 1.6em;
  width: 42%;
  position: relative;
  background: white;
  border-radius: 0.25em;
  padding: 1em;
  box-shadow: 0 3px 0 #d7e4ed;
}
.cd-timeline-content .cd-date {
  position: absolute;
  width: 100%;
  left: 122%;
  top: 6px;
  font-size: 16px;
  font-size: 1rem;
}
.cd-timeline-block:nth-child(even) .cd-timeline-content .cd-date {
  left: auto;
  right: 122%;
  text-align: right;
}
.cd-timeline-block:nth-child(even) .cd-timeline-content {
  float: right;
}
.cd-timeline-block:after {
  content: "";
  display: table;
  clear: both;
}
.cd-timeline-img {
  width: 60px;
  height: 60px;
  left: 50%;
  margin-left: -30px;
  -webkit-transform: translateZ(0);
  -webkit-backface-visibility: hidden;
}
.cd-timeline-img {
  position: absolute;
  top: 0;
  border-radius: 50%;
  box-shadow: 0 0 0 4px white, inset 0 2px 0 rgba(0, 0, 0, 0.08), 0 3px 0 4px rgba(0, 0, 0, 0.05);
  background: #105a8b;
}
.cd-timeline-img img,.cd-timeline-img svg {
  display: block;
  width: 24px;
  height: 24px;
  position: relative;
  left: 50%;
  top: 50%;
  margin-left: -12px;
  margin-top: -12px;
  vertical-align: middle;
}
.cssanimations .cd-timeline-img.is-hidden,.cssanimations .cd-timeline-content.is-hidden {
  visibility: hidden;
}
.cssanimations .cd-timeline-img.bounce-in,.cssanimations .cd-timeline-content.bounce-in {
  visibility: visible;
  animation: cd-bounce-1 0.6s;
}
@keyframes cd-bounce-1 {
  0% {
    opacity: 0;
    transform: scale(0.5);
  }
  60% {
    opacity: 1;
    transform: scale(1.2);
  }
  100% {
    transform: scale(1);
  }
}

execcodegetcode

你可以按照自己喜欢的任何方式设置时间线元素的样式,使用与以下相关的相应 CSS 规则:位置、底部、宽度、高度、填充、背景、边框样式。

一些 Web 开发人员更喜欢随着时间线的推移对元素进行不同的样式设置。例如,你可能希望为每个其他条目设置不同的样式,以便提供一种区分它们的方法。或者,你可以根据某个预先确定的类别设计不同的元素。

您可能对以下文章也感兴趣

  • 纯CSS3实现的时间线 (Timeline),非常实用