1、什么是复合选择器
在css中,可以根据选择器的类型把选择器分为基础选择器 和复合选择器,复合选择器是建立在基础选择器之上,对基本选择器进行组合形成的。
- 复合选择器可以更准确、更高效的选择目标元素(标签)
- 复合选择器是由两个或多个基础选择器,通过不同的方式组合而成的
- 常用的复合选择器包括: 后代选择器、子选择器、并集选择器、伪类选择器等等
2、后代选择器
后代选择器又称为包含选择器,可以选择父元素里面子元素。其写法就是把外层标签写在前面,内层标签写在后面,中间用空格分隔。当标签发生嵌套时,内层标签就称为 外层标签的后代
元素1 元素2 {样式声明}
表示选择元素1 里面的所有元素2(后代元素)
例如:
ul li {样式声明}
选择 ul 里面所有的li标签元素
- 元素1 和元素2中间用空格隔开
- 元素1 是父级,元素2是子级,最终选择的是元素2
- 元素2 可以是儿子,也可以是孙子等,只要是元素1的后代即可
- 元素1 和元素2可以是任意基础选择器
3、子选择器
子元素选择器(子选择器) 只能选择作为某元素的最近一级子元素。简单理解就是选亲儿子元素
元素1 > 元素2 {样式声明}
上述语法表示选择元素1 里面的所有直接后代(子元素) 元素2
例如:
div > p {样式声明}
选择 div 里面所有最近一级 p标签元素
- 元素1 和元素2 中间用 大于号 隔开
- 元素1 是父级,元素2 是子级,最终选择的是元素2
- 元素2 必须是亲儿子,其孙子、重孙之类都不归它管
4、并集选择器
并集选择可以选择多组标签,同时为它们定义相同的样式。通常用于集体声明
并集选择器 是各选择器通过 英文逗号(,)连接而成,任何形式的选择器都可以作为并集选择器的一部分
元素1,元素2 {样式声明}
上述语法表示选择元素1 和元素2
例如:
ul,div {样式声明}
选择ul和div标签
- 元素1 和元素2 中间用逗号隔开
- 逗号可以理解为 和的艺术
- 并集选择器通常用于集体声明
5、伪类选择器
伪类选择器用于向某些选择器添加特殊的效果,比如给链接添加特殊效果,或选择第1个,第n个元素
伪类选择器书写的最大的特点是 用冒号 : 表示
- 选择所有未被访问的链接 a:link
- 选择所有已被访问的链接 a:visited
- 选择鼠标指针位于其他上的链接 a:hover
- 选择活动链接(鼠标按下未弹起的链接) a:active
6、链接伪类选择器
为了确保生效,请按照 LVHA的循顺序声明:
:link - :visited :hover :active
a链接在浏览器中具有默认样式,所以我们实际工作中都需要给链接单独指定样式
链接伪类选择器实际工作开发中的写法:
a {
color: gray;
}
a:hover {
color: red;
}
7、 :focus 伪类选择器
:focus伪类选择器用于选取获得焦点的表单元素
焦点就是光标,一般情况 input 类表单元素才能获取,因此这个选择器也注意针对于表单元素来说
input:focus {
background-color:yellow;
}