使用css实现时间轴

本文将使用css来实现一个左右交叉布局的时间轴,效果如下:

使用的都是一些常用的css,代码如下:

  1 <!DOCTYPE>
  2 <html>
  3 <head>
  4     <title>vue demo</title>
  5     <script src="js/jquery-3.2.1.js"></script>
  6     <style>
  7         .lv-time-section{
  8             font-size:0;
  9             width:100%;
 10         }
 11         .lv-time-left, .lv-time-right{
 12             display:inline-block;
 13             width:calc(50% - 1px);
 14             height:100px;
 15         }
 16         
 17         .lv-time-left{
 18             border-right:2px solid #949494;
 19         }
 20         
 21         .lv-time-time, .lv-time-container{
 22             font-size:16px;
 23         }
 24         
 25         .lv-time-container{
 26             background-color:#949494;
 27             border-radius:5px;
 28         }
 29         .lv-time-content{
 30             padding:5px;
 31         }
 32         
 33         .lv-time-left .lv-time-container, 
 34         .lv-time-left .lv-time-time,
 35         .lv-time-left .lv-time-container .lv-time-content{
 36             float:right;
 37         }
 38         
 39         .lv-time-right .lv-time-container, 
 40         .lv-time-right .lv-time-time,
 41         .lv-time-right .lv-time-container .lv-time-content{
 42             float:left;
 43         }
 44         
 45         .lv-time-left .lv-time-time:after{
 46             content:"";
 47             display:inline-block;
 48             height:10px;
 49             width:10px;
 50             border-radius:5px;
 51             background-color:#949494;
 52             margin-right:-6px;
 53         }
 54         
 55         .lv-time-right .lv-time-time:before{
 56             content:"";
 57             display:inline-block;
 58             height:10px;
 59             width:10px;
 60             border-radius:5px;
 61             background-color:#949494;
 62             margin-left:-6px;
 63         }
 64         
 65         .lv-time-container{
 66             border:1px solid #949494;
 67         }
 68         
 69         .lv-time-left .lv-time-container{
 70             margin-right:15px;
 71             text-align:right;
 72         }
 73         
 74         .lv-time-right .lv-time-container{
 75             float:left;
 76             margin-left:15px;
 77             padding-right:10px;
 78             text-align:left;
 79             
 80         }
 81         
 82         .lv-time-left .lv-time-container:after{
 83             content:"";
 84             display:block;
 85             float:right;
 86             border-top:5px solid transparent;
 87             border-left:10px solid #949494;
 88             border-bottom:5px solid transparent;
 89             margin-right:-100%;
 90             margin-top:5px;
 91         }
 92         
 93         .lv-time-right .lv-time-container:before{
 94             content:"";
 95             display:block;
 96             float:left;
 97             border-top:5px solid transparent;
 98             border-right:10px solid #949494;
 99             border-bottom:5px solid transparent;
100             margin-left:-11px;
101             margin-top:5px;
102         }
103         
104     </style>
105 </head>
106 <body>
107     <div class="lv-time-section">
108         <div class="lv-time-left">
109             <div class="lv-time-time">
110             2018-05-13
111             </div>
112         </div>
113         <div class="lv-time-right">
114             <div class="lv-time-container">
115                 <div class="lv-time-content">
116                     开篇-springboot环境搭建
117                 </div>
118             </div>
119         </div>
120     </div>
121     <div class="lv-time-section">
122         <div class="lv-time-left">
123             <div class="lv-time-container">
124                 <div class="lv-time-content">
125                     引入springmvc
126                 </div>
127             </div>
128         </div>
129         <div class="lv-time-right">
130             <div class="lv-time-time">
131             2018-05-14
132             </div>
133         </div>
134     </div>
135     <div class="lv-time-section">
136         <div class="lv-time-left">
137             <div class="lv-time-time">
138             2018-05-15
139             </div>
140         </div>
141         <div class="lv-time-right">
142             <div class="lv-time-container">
143                 <div class="lv-time-content">
144                     添加多个控制器
145                 </div>
146             </div>
147         </div>
148     </div>
149     <div class="lv-time-section">
150         <div class="lv-time-left">
151             <div class="lv-time-container">
152                 <div class="lv-time-content">
153                     添加后台管理页面
154                 </div>
155             </div>
156         </div>
157         <div class="lv-time-right">
158             <div class="lv-time-time">
159             2018-05-16
160             </div>
161         </div>
162     </div>
163     <div class="lv-time-section">
164         <div class="lv-time-left">
165             <div class="lv-time-time">
166             2018-05-17
167             </div>
168         </div>
169         <div class="lv-time-right">
170             <div class="lv-time-container">
171                 <div class="lv-time-content">
172                     添加权限管理模块
173                 </div>
174             </div>
175         </div>
176     </div>
177     <div class="lv-time-section">
178         <div class="lv-time-left">
179             <div class="lv-time-container">
180                 <div class="lv-time-content">
181                     使用ueditor添加文章
182                 </div>
183             </div>
184         </div>
185         <div class="lv-time-right">
186             <div class="lv-time-time">
187             2018-05-18
188             </div>
189         </div>
190     </div>
191     <div class="lv-time-section">
192         <div class="lv-time-left">
193             <div class="lv-time-time">
194             2018-05-19
195             </div>
196         </div>
197         <div class="lv-time-right">
198             <div class="lv-time-container">
199                 <div class="lv-time-content">
200                     前端文章分页功能实现
201                 </div>
202             </div>
203         </div>
204     </div>
205     <div class="lv-time-section">
206         <div class="lv-time-left">
207             <div class="lv-time-container">
208                 <div class="lv-time-content">
209                     将博客部署到tomcat上
210                 </div>
211             </div>
212         </div>
213         <div class="lv-time-right">
214             <div class="lv-time-time">
215             2018-05-20
216             </div>
217         </div>
218     </div>
219 </body>
220 </html>
time.html

实现上是这样考虑的,时间轴的每一小节都是一个独立的节点,这样每个小结就对应一个lv-time-section节点,而为了实现左右交叉布局,所以这儿定义了一个lv-time-left和lv-time-right,这样将时间和内容分别交叉放入各自的left和right div中,也就达到了交叉的效果。而中间的时间线则是通过给lv-time-left添加有边框来实现的;圆点是通过给lv-time-time添加after和before伪类来实现的,然后通过lv-time-time在那个div下面设置圆点的位置即可。而lv-time-content的尖号也是通过这种方式实现的。
这样的展示效果显得有层次感,我这儿是为了展示文章列表的,所以在结合下拉刷新的功能的话,相比于分页会更有用户体验效果。希望本文对你有所帮助。

原文地址:https://www.cnblogs.com/lvniao/p/9101786.html