在很多项目中,需要实现分格展示的功能,中间有灰色分割线,两侧没有。
如图:
按照一般的思路,设置好li的宽度,通过nth-of-type(n){}的方式给li标签添加样式。
设置每个li 33.33%的宽度,但当我们添加1px边框时,最右边的内容就被挤了下来。
这时可以通过给父级 ul 添加:before :after 伪类元素来实现。而不占用li的width
当显示3列时,通过给ul 添加:before来实现
CSS
<style>
ul li{ list-style: none;}
.mp-list{
position: relative;
overflow: hidden;
z-index: 0;
background-color: #fff;
}
.mp-list:before {
content: '';
position: absolute;
width: 33.33%;
left: 33.33%;
height: 100%;
border-left: .02rem solid #ddd;
border-right: .02rem solid #ddd;
}
.mp-list li {
width: 33.33%;
height: 2rem;
line-height: 2rem;
font-size: .28rem;
text-align: center;
border-bottom: .02rem solid #ddd;
margin-bottom: -1px;
float: left;
position: relative;
z-index: 10;
color: #212121;
}
.mp-list li a {
color: #212121;
display: block;
overflow: hidden;
text-overflow: ellipsis;
white-space: nowrap;
font-size: .28rem;
}
</style>
HTML
<ul class="mp-list">
<li><a hybrid-link="" href="" title="">香港</a></li>
<li><a hybrid-link="" href="" title="">澳门</a></li>
<li><a hybrid-link="" href="" title="">台湾</a></li>
<li><a hybrid-link="" href="" title="">曼谷</a></li>
<li><a hybrid-link="" href="" title="">新加坡</a></li>
<li><a hybrid-link="" href="" title="">首尔</a></li>
<li><a hybrid-link="" href="" title="">东京</a></li>
<li><a hybrid-link="" href="" title="">济州岛</a></li>
<li><a hybrid-link="" href="" title="">芭堤雅</a></li>
</ul>
当显示4列时,给:after添加样式,注意需要更改li的width、.mp-list:before的位置。
.mp-list:after {
content: '';
position: absolute;
width: 10%;
left: 75%;
height: 100%;
border-left: .02rem solid #ddd;
border-right: 0;
}
**粗体** _斜体_ [链接](http://example.com) `代码` - 列表 > 引用
。你还可以使用@
来通知其他用户。