CSS的垂直时间轴

时间:2016-05-06 17:43:10

标签: html css

我正在尝试创建一个垂直时间轴,其中包含一些图标。 我用this作为我的起点。我以某种方式设法在div内额外跨度。

然而它看起来有点混乱。因为我使用白色背景来隐藏线条,并使用额外的跨度来添加图像。

您是否可以查看我的代码并帮助我根据id classli添加不同的图片

感谢。 总的来说,我想实现 1.根据li的类或id添加图像 2.删除所有不必要的span img标记以清除代码。

My Version

摘录:



body{
  line-height:1.3em;
}
.history-tl-container{
    font-family: "Roboto",sans-serif;
  width:50%;
  margin:auto;
  display:block;
  position:relative;
}
.history-tl-container ul.tl{
    margin:20px 0;
    padding:0;
    display:inline-block;

}

span.check {
width: 24px;
height: 24px;
background-repeat: no-repeat;
background-image: url();
    background-repeat: no-repeat;
    left: -14px;
    position: absolute;
    padding: 20px; 
}


.history-tl-container ul.tl li{
    list-style: none;
    margin:auto;
    margin-left:200px;
    min-height:50px;
    border-left:1px solid #86D6FF;
    padding:0 0 50px 30px;
    position:relative;
}
.history-tl-container ul.tl li:first-child:before{ 
	background: rgba(138, 223, 199, 1) none repeat scroll 0 0;
}

.history-tl-container ul.tl li:last-child{ border-left:0;}
.history-tl-container ul.tl li::before{
    background: #FFFFFF none repeat scroll 0 0;
    border: 2px solid rgba(138, 223, 199, 0.74);
    border-radius: 500%;
    content: " ";
    height: 30px;
    left: -18px;
    position: absolute;
    top: -5px;
    transition: all 500ms ease-in-out 0s;
    width: 30px;

}
/* .history-tl-container ul.tl li:hover::before{
    border-color:  #258CC7;
    transition: all 1000ms ease-in-out;
} */
ul.tl li .item-title{
}
ul.tl li .item-detail{
    color:rgba(0,0,0,0.5);
    font-size:12px;
}
ul.tl li .timestamp{
    color: #8D8D8D;
    position: absolute;
  width:100px;
    left: -50%;
    text-align: right;
    font-size: 12px;
}

<div class="history-tl-container">
  <ul class="tl">
    <li class="tl-item" ng-repeat="item in retailer_history">
   
<span class="check"></span>
        <div class="timestamp">
        3rd March 2015<br> 7:00 PM
      </div>
      <div class="item-title">Start from Shire</div>
      <div class="item-detail">Don't forget the ring</div>
    </li>
    <li class="tl-item" ng-repeat="item in retailer_history">
      <div class="timestamp">
        19th March 2015<br> 3:00 PM
      </div>
      <div class="item-title">Kill some Orcs</div>
      <div class="item-detail">Don't enter the caves!!</div>
    </li>
    <li class="tl-item" ng-repeat="item in retailer_history">
      <div class="timestamp">
        1st June 2015<br> 7:00 PM
      </div>
      <div class="item-title">Throw that goddamn ring in the lava</div>
      <div class="item-detail">Also, throw that Gollum too</div>
    </li>

  </ul>

</div>
&#13;
&#13;
&#13;

1 个答案:

答案 0 :(得分:1)

您可以使用::after属性。

.history-tl-container ul.tl li.achieved::after {
   content: "";
   width: 24px;
   height: 24px;
   position: absolute;
   top: 0;
   left: -14px;
   background-repeat: no-repeat;
   background-image: url();
   background-repeat: no-repeat;
   left: -14px;
}

注意,你必须添加&#34;达到&#34;应该显示检查的li的类。此外,您可以使用此类突出显示绿色。

.history-tl-container ul.tl li.achieved::before{ 
   background: rgba(138, 223, 199, 1) none repeat scroll 0 0;
}

但是,跨度没有问题,但是如果你使用我的解决方案,你应该摆脱它。