文章目录
- 复合选择器是建立在基础选择器之上,对 基本选择器进行组合形成的。
- 常用的复合选择器包括:后代选择器、子选择器、并集选择器、伪类选择器等等
5.1 后代选择器
- 选择父元素里面子元素。其写法就是把外层标签写在前面,内层标签写在 后面,中间用空格分隔。当标签发生嵌套时,内层标签就成为外层标签的后代。
- 语法如下:
元素1 元素2 { 样式声明 }
- 表示选择元素1中的所有元素2,元素2 可以是儿子,也可以是孙子等,只要是元素1 的后代即可
- 元素1 和 元素2 可以是任意基础选择器
ul li {color:red}
5.2 子选择器
- 子元素选择器(子选择器)只能选择作为某元素的最近一级子元素。简单理解就是选亲儿子元素
- 语法:
元素1 > 元素2 { 样式声明 }
-
表示选择元素1 里面的所有直接后代(子元素) 元素2。
-
代码
div > p { color:red } /* 选择 div 里面所有最近一级 p 标签元素 *
5.3 并集选择器
- 并集选择器可以选择多组标签, 同时为他们定义相同的样式。通常用于集体声明.
- 并集选择器是各选择器通过英文逗号(,)连接而成,任何形式的选择器都可以作为并集选择器的一部分。
- 语法:
元素1,元素2 { 样式声明 }/*表示选择了元素1标签和元素2标签*/
- 代码:
ul,div { 样式声明 } /* 选择 ul 和 div标签元素 */
5.4 伪类选择器
- 伪类选择器用于向某些选择器添加特殊的效果,比如给链接添加特殊效果,或选择第1个,第n个元素。
- 伪类选择器书写最大的特点是用冒号(:)表示,比如 :hover 、 :first-child
5.4.1 链接伪类选择器
5.4.1.1 整体说明
- 为了确保生效,请按照 LVHA 的循顺序声明 :link-:visited-:hover-:active。
声明 | 说明 |
---|---|
link | 设置a对象在未被访问前的样式表属性 |
visited | 设置a对象在其链接地址已被访问过时的样式表属性 |
hover | 设置对象在其鼠标悬停时的样式表属性 |
active | 设置对象在被用户激活(在鼠标点击与释放之间发生的事件)时的样式表属性 |
5.4.1.2 hover 选择器举例说明使用
-
hover伪类选择器
-
作用:选中鼠标悬停在元素上的状态,设置样式
-
语法:
选择器:hover { css }
-
代码:
a : hover{color:red}
5.4.1.3 整合举例说明
<style>
/* 1.设置a对象在未被访问前的样式表属性 */
a:link {
color: blue;
}
/* 2.设置a对象在其链接地址已被访问过时的样式表属性 */
a:visited {
color: orange;
}
/* 3.设置对象在其鼠标悬停时的样式表属性 */
a:hover {
color: red;
}
/* 4.设置对象在被用户激活(在鼠标点击与释放之间发生的事件)时的样式表属性 */
a:active {
color: black;
}
</style>
5.4.2 :focus 伪类选择器
-
:focus 伪类选择器用于选取获得焦点的表单元素。
-
焦点就是光标,一般情况 类表单元素才能获取,因此这个选择器也主要针对于表单元素来说
input:focus {
background-color:blue;
}
5.5 复合选择器总结
选择器 | 作用 | 特征 | 使用情况 | 符号及其用法 |
---|---|---|---|---|
后代选择器 | 选择后代元素 | 可以选择任意 后代 | 较多 | 空格 .nav a |
子代选择器 | 选择最近一级元素 | 只能选择直接后代 | 较少 | 大于号 .nav>p |
并集选择器 | 选择某些相同样式的元素 | 用于集体声明 | 较多 | 逗号 .nav,header |
链接伪类选择器 | 选择不同状态的链接 | 跟链接相关 | 较多 | 冒号 a:hovor{} |
:focus选择器 | 选择获得光标的表单 | 跟跟表单相关 | 较少 | 冒号 input:focus{} |