属性选择器
属性选择器可以根据元素特定属性的来选择元素。这样就可以不用借助于类或者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元素
注意:类选择器、属性选择器、伪类选择器,权重为10.
结构伪类选择器
结构伪类选择器主要根据文档结构来选择器元素,常用于根据父级选择器里面的子元素
选择符 简介
E:first-child 匹配父元素中的第一子元素E
E:last-child 匹配父元素中最后一个E元素
E:last-child(n) 匹配父元素中的第n个子元素E
E:first-of-type 指定类型E的第一个
E:last-of-type 指定类型的最后一个
E:nth-of-type(n) 指定类型E的第n个
区别:
1. nth-child 对父元素里面所有孩子排序选择(序号是固定)先找到第n个孩子,然后看看是否个E匹配
2. nth-of-type 对父元素里面指定子元素进行排序选择,先去匹配E,找第n个孩子
nth-child(n)选择某个父元素的一个或多个特定的子元素
n可以是数字,关键字和公式
n如果是数字,就是选择第n个子元素,里面数字从1开始
n可以是关键字:even 偶数,odd 奇数
n可以是公式:常见的公式如下(如果n是公式,则从0开始计算,但是第0个元素或者超出了元素的个数会被忽略)
公式 取值
2n 偶数
2n+1 奇数
5n 5 10 15……
n+5 从第5个开始(包括第五个)到最后
-n+5 前5个(包括第5个)……
伪元素选择器(重点)
伪元素选择器可以帮助我们利用CSS创建新标签元素,而不需要HTML标签,从而简化HTML结构。
选择符 简介
::before 在元素内部的前面插入内容
::after 在元素内部的后面插入内容
注意:
before和after创建一个元素,但是属于行内元素;
新创建的这个元素在文档树中是找不到的,所以我们称为伪元素
语法:elementt::before{}
before和after 必须有content 属性
before 在父元素内容的前面创建元素,after在父元素内容的后面插入元素
伪元素选择器和标签选择器一样,权重为1
伪元素选择器:伪元素清除浮动
后面两种伪元素清除浮动算是第一种额外标签发的一个升级和优化。
.clearfix:after {
content:""; 伪元素必须写的属性
display: block; 插入的元素必须是块级
height: 0; 不要看见这个元素
clear: both; 核心代码清除浮动
visibility: hidden; 不要看见这个元素
}