伪类 + 伪元素
一、伪类和伪元素的区别:
1.1、它们是否创造了新的元素并且必须和 contern: ”“ 相结合才可以进行使用。
· 伪类:用于向某些选择器添加特殊的效果
伪元素:相当于创建了一个新的标签 比如span 所以是创造了新的元素。
1.2、伪类只能使用“:”
而伪元素既可以使用“:”,也可以使用“::”
1.3、伪类是类似于添加类所以可以是多个,而伪元素在一个选择器中只能出现一次,并且只能出现在末尾
二、一个 冒号和两个冒号的区别
:after/::after和:before/::before的异同
相同点
都可以用来表示伪类对象,用来设置对象前的内容
:before和::before写法是等效的; :after和::after写法是等效的
不同点
:before/:after是Css2的写法,::before/::after是Css3的写法
:before/:after 的兼容性要比::before/::after好
伪元素要配合content属性一起使用
经常使用的伪类有:
1 :active 选择正在被激活的元素(匹配指定状态)
2 :hover 选择被鼠标悬浮着的元素(匹配指定状态)
3 :link 选择未被访问的元素 (匹配指定状态)
4 :visited 选择已被访问的元素(匹配指定状态)
5 :first-child 选择满足是其父元素的第一个子元素的元素
6 :lang(value) 选择带有指定 lang 属性的元素
7 :focus 选择拥有键盘输入焦点的元素
8 :enable 选择每个已启动的元素
9 :disable 选择每个已禁止的元素
10 :checked 选择每个被选中的元素
11 :target 选择当前的锚点元素
12 :first-of-type 选择满足是其父元素的第一个某类型子元素的元素
13 :last-of-type 选择满足是其父元素的最后一个某类型子元素的元素
14 :only-of-type 选择满足是其父元素的唯一一个某类型子元素的元素
15 :nth-of-type(n) 选择满足是其父元素的第n个某类型子元素的元素
16 :nth-last-of-type(n) 选择满足是其父元素的倒数第n个某类型的元素
17 :only-child 选择满足是其父元素的唯一一个子元素的元素 只有是唯一存在的才有效
18 :last-child 选择满足是其父元素的最后一个元素的元素
19 :nth-child(n) 选择满足是其父元素的第n个子元素的元素 你想选择第几个就是第几个
:nth-child(odd) 偶数 就是下标是偶数
:nth-child(odd) 奇数 就是小标是奇数
20 :nth-last-child(n) 选择满足是其父元素的倒数第n个子元素的元素
21 :empty 选择满足没有子元素的元素 就是内容是空的元素。
22 :in-range 选择满足值在指定范围内的元素
23 :out-of-range 选择值不在指定范围内的元素
24 :invalid 选择满足值为无效值的元素
25 :valid 选择满足值为有效值的元素
26 :not(selector) 选择不满足selector的元素
27 :optional 选择为可选项的表单元素,即没有“required”属性
28 :read-only 选择有"readonly"的表单元素
29 :read-write 选择没有"readonly"的表单元素
30 :root 选择根元素 就和html 以及body 一样的元素
经常使用的伪元素有:
1 伪元素为DOM树没有定义的虚拟元素。不同于其他选择器,它不以元素为最小选择单元,它选择的是元素指定内容。比如::before表示选择元素内容的之前内容,也就是"";
::selection表示选择元素被选中的内容。
2 ::first-letter 选择指定元素的第一个单词
3 ::first-line 选择指定元素的第一行
4 ::after 在指定元素的内容前面插入内容 //不能被低版本的使用。 zoom: 1 这个是低版本的写法。
5 ::before 在指定元素的内容后面插入内容
6 ::selection 选择指定元素中被用户选中的内容

浙公网安备 33010602011771号