属性选择器
根据元素特定属性的来选择元素,而不需动用类或id选择器
- E[att] 选择具有att属性的E元素
- E[att="val"] 选择具有att属性值等于val的E元素 (重点)
- E[att^="val"] 匹配具有att属性值以val开头的E元素
- E[att$="val"] 匹配具有att属性且值以val结尾的E元素
- E[att*="val"] 匹配具有att属性且值中含有val的E元素
input[type="text"] {
color: pink;
}
注意:类选择器,属性选择器,伪类选择器这些权重为10
结构伪类选择器
主要根据文档结构来选择元素,常用于根据父级选择里面的子元素
- E:first-child 匹配元素中的第一个元素E
- E:last-child 匹配父元素中的最后一个E元素
- E:nth-child(n) 匹配父元素中的第n各子元素E
- E:first-of-type 指定类型E的第一个
- E:last-of-type 指定类型E的最后一个
- E:nth-of-type(n) 指定类型E的第n个
th-child(n):
- n可以是数字,关键字或公式
- n如果是数字,就是选择第n个子元素,里面数字从1开始
- n可以是关键字,even偶数,odd奇数
- n可以是公式:常见的公式如下(如果n施工时,则从0开始计算,但是第0各元素或者超出了元素的个数会被忽略)
- 所有孩子排序,之后看前面的选择器
数字
/* 选择ul里面的第三个li */
ul li:nth-child(3) {
color: red;
}
关键字
/* 隔行换色 */
ul li:nth-child(even) {
background-color: #ccc;
}
ul li:nth-child(odd) {
background-color: gray;
}
公式
/* 选择全部 */
ul li:nth-child(n) {
background-color: gray;
}
其中,公式可以为:
- n 全部
- 2n 偶数
- 2n+1 奇数
- n+2 从第五个(包括第五个)倒最后
- -n+5 前5个(包括第五个)
nth-of-type(n)
- 将指定的孩子排列序号
- 先看选择器,然后看第几个孩子
- 写法和nth-child类似
nth-child与nth-of-type区别
1.nth-child对父元素里面所有的孩子排序选择(序号是固定的),先找到第n个孩子,然后看看是否和E匹配
2.nth-of-type对父元素里面指定元素进行排序选择,先去匹配E,然后找第几个孩子
伪元素选择器(重点)
伪元素选择器可以帮助我们利用CSS创建新标签元素,而不需要HTML标签,从而简化HTML结构
- ::before 在元素内部的前面插入内容
- ::after 在元素内部的后面插入内容
注意:
1.被before和after常见一个元素,单时属于行内元素
2.新创建的这个元素在文档中是找不到的,所以我们称之为为元素
3.语法: element::before {}
4.before和after必须有 content属性
5.before在父元素内容的前面创建元素,after则在后面
6.为元素选择器和标签选择器一样,权重为1
p::before {
position: absolute;
right: 20px;
top: 10px;
content: '\e91e';
fonst-size: 20px;
}