有的时候设计小姐姐非常的任性,给出一大堆颜色千奇百怪的toolbar,怎么办?
好气喔,还是得认认真真的画
首先看 效果如下
data:image/s3,"s3://crabby-images/1d24d/1d24d504f15b8cfde3155ddc417cc70c6e87fc30" alt=""
我们不用给每一个btn单独添加bg色值,一个:nth-child就可以完美实现,以下描述的地方我们统称为nth,前情提要,我使用的css预处理器是stylus,下面的变量将都会以stylus的语法陈述
nth是css3的伪类选择器大致用法有以下几种
1、指定数值
举例说明: 1)需求-将一个列表中的第1(x)项标记红色
实现
//声明方法
add(a)
a = unit(a,px)
bg()
background arguments
.tab-group
height add(200)
display flex
align-items $ct
justify-content $ct
.tab-items
height add(80)
width add(80)
line-height add(40)
border-radius add(40)
margin-right add(20)
text-align ct
bg(base-col)
&:nth-child(1)
bg(col1)
效果:
data:image/s3,"s3://crabby-images/2f968/2f968dec522dee2afd9eaf6f86fb5f1eb3dd3b2f" alt=""
2.指定周期
举例说明: 1)需求-列表实现单双色轮换
实现
&:nth-child(2n)
bg(col4)
或 &:nth-child(even)
bg(col4)
效果:
data:image/s3,"s3://crabby-images/c06e5/c06e55c3915ee04231664a654125a25afda1d6b6" alt=""
3.周期分组
举例说明:1)需求-列表实现三色一组轮换
实现
&:nth-child(3n+1)
bg(col4)
&:nth-child(3n+2)
bg(col5)
&:nth-child(3n+3)
bg(col6)
效果:
data:image/s3,"s3://crabby-images/7a6f1/7a6f13e40e4b36c50e8060e20118c5e7aa63bf24" alt=""
这里的n我是这样理解的 n就是一个组 2n就是两个元素一组 3n就是三个元素一组,以此类推,+-的基准都是以当前组的第一个元素开始计算,当然超过组别大小会跑到隔壁组进行渲染 比如
&:nth-child(2n+4)
bg($col4)
效果:
data:image/s3,"s3://crabby-images/cb09b/cb09b9ba5bf94a74f081b5b0a5f828aee06ad77c" alt=""
歪! 你跑到隔壁去啦!
有了这个神器,只需要定义好颜色值,不管多么眼花缭乱的效果,都给设计小姐姐完成的漂漂亮亮的,并且不需要添加许许多多low炸天的style1,style2,style3,想class名想的头要炸裂有木有
给自己强化一下,所以做个笔记,还有一些用法我没有一一列举,个人感觉这三个 就很实用啦 有什么错误欢迎友好指正!
不准很凶!
网友评论