css 实现 flex 布局下,奇数行正向排序,偶数行反向排序
目标效果:
data:image/s3,"s3://crabby-images/08d61/08d6127d6c83f169e513fd8d02d49dcaf7379d93" alt="Jx4v0P.md.png"
data:image/s3,"s3://crabby-images/ebc72/ebc729017fdae905ad6202ff01ef52e6546db0ed" alt="Jx4jmt.md.png"
<ul>
<li v-for="(item,index) in listArr" :key="index">
{{ index }}
</li>
</ul>
第一种解决方案 - scss/flex-order
ul {
display: flex;
flex-direction: row;
flex-wrap: wrap;
li {
position: relative;
flex-grow: 1;
width: 20%;
height: 160px;
padding-top: 12rpx;
border: 0 solid #b3b3b3;
border-top-width: 2rpx;
text-align: center;
&.active {
border-top-color: #3f4c8c;
&::before {
border: 4rpx solid #3f4c8c;
}
}
&::before {
content: "";
position: absolute;
top: 0;
left: 50%;
transform: translate(-50%, -50%);
width: 24rpx;
height: 24rpx;
background: #ffffff;
border: 4rpx solid #999999;
border-radius: 50%;
}
&:nth-child(10n + 6):last-child {
border-top-width: 2rpx;
width: 80%;
}
@for $i from 0 through 150 {
&:nth-child(#{$i + 1}) {
@if ($i + 1)/5 % 2==1 {
border-right-width: 2rpx;
border-bottom-width: 2rpx;
border-radius: 0 50% 50% 0;
} @else if ($i + 1)/5 % 2==0 {
border-left-width: 2rpx;
border-bottom-width: 2rpx;
border-radius: 50% 0 0 50%;
} @else if $i%5==0 and $i!=0 {
border-top-width: 0;
flex-grow: 0;
}
@if floor($i / 5) % 2 == 0 {
order: #{$i};
} @else {
order: #{$i + (2 - ($i % 5)) * 2};
}
@if floor($i/5) >0 {
margin-top: -2rpx;
}
}
}
}
}
第二种解决方案 float/nth-child()
ul > li:nth-child(10n + 6),
ul > li:nth-child(10n + 7),
ul > li:nth-child(10n + 8),
ul > li:nth-child(10n + 9),
ul > li:nth-child(10n) {
float: right;
}