00、CSS选择器架构
CSS的选择器分类如下图,其中最最基本的就是基础选择器中的三种:元素选择器、类选择器、id选择器。伪类选择器就是元素的不同行为、状态,或逻辑。然后不同的选择器组合,基于不同的组合关系,产生了6中组合关系选择器。
01、通配选择器:*{}
针对所有HTML标签全部适用,选择器名=星号*
(通配符),一般只做初始化使用。在 CSS3 中,星号 () 可以和命名空间组合使用,如`ns|{}`。
/* 通用选择器,针对所有标签 */
* {
color: black;
font-size: 15px;
}
02、元素/标签选择器:元素名{}
用元素名称作为选择器名称,如p、h1、div、img等几乎所有元素名,对作用域内所有该标签元素生效,所以常用来描述某一元素的共性。
hr {
margin: 32px 5px;
}
h1 {
background-color: lightblue;
text-indent: 0.5em;
}
03、类选择器:.类名{}
定义时前面见点.类名
,在标签的属性“class”使用该样式。
/* 类名class选择器 */
.particle{
font-size: 18px;
font-family: 楷体;
}
.pindent{
text-indent: 2em;
}
<p class="particle pindent">一段文字内容-section</p>
类选择器可以给所有需要的标签使用,可同时给多个标签使用,应用广泛。
- 类名不能以数字开头。
- 同一个标签也可以用多个类选择器,空格隔开。
04、id选择器:#id{}
用标签的id作为选择器名称,加井号“#
”,针对作用域内指定id的标签生效,所以只能使用一次。
- ID是标签的唯一标识,不能重复。如果重复,样式其实是会生效的,但查找元素(document.getElementById(id))只会返回第一个。
- ID不能以数字开头。
/* id选择器 */
#a1{
color:blueviolet;
font-size: 16px;
text-decoration-line:underline ;
}
05、属性选择器:选择器[属性]{} css3
元素都有属性,属性选择器是在其他选择器的基础上加上属性的筛选,用来筛选有特定属性、或属性值的元素。这里的属性值匹配是大小写敏感的,结尾加上字符i
(li[title*= "a" i]
),则会忽略大小写敏感。
选择器 | 示例 | 描述 |
---|---|---|
[attr] | li[title]``.cli[title] |
筛选li元素 且有属性title 的元素 |
[attr=value] | li[title="a"] |
筛选li元素 且有属性title 的元素,且其属性值相等的元素。 |
[attr~=value] | li[title~="a"] |
同上,属性值是值包含,注意是值包含(如多个样式名),不是字符匹配包含,空格隔开的字符也算。 |
[attr|=value] | li[title|="a"] |
同上,属性值是a,或开始为a且后面跟连字符- (中划线) |
[attr^=value] | li[title^= "a"] |
属性值字符匹配:开头字符匹配 |
[attr$=value] | li[title$= "a"] |
属性值字符匹配:结尾字符匹配 |
[attr*=value] | li[title*= "a"] |
属性值字符匹配:包含字符匹配 |
<style>
li[title]{
color: red;
}
li[title="a"]{
font-weight: bold;
}
li[title~="a"]{
text-decoration: underline;
}
li[title|="a"]{
text-indent: 2em;
}
li[title^= "a"]{
text-shadow: 2px 2px 3px black;
}
li[title$= "a"]{
background: center url(../res/bimg.jpg);
}
li[title*= "a"]{
background-color: azure;
}
.cli[title]{
font-style: italic;
}
</style>
<ul>
<li title="a">item1:a</li>
<li title="a b">item2:a b</li>
<li title="c a b">item2</li>
<li title="a-b" class="cli">item4:a-b</li>
<li title="abc" class="cli">item5:abc</li>
<li title="cab" class="cli">item6:cab</li>
<li title="cba" class="cli">item7:cba</li>
<li title="cbA1" class="cli">item8:cbA1</li>
</ul>
06、伪类选择器
6.1、什么是伪类?-伪类选择器:
伪类是选择器的一种,它用于选择处于特定状态的元素。比如第一个元素、最后一个、奇数序列,或者是当鼠标指针悬浮。和用户交互有关的伪类,也叫用户行为伪类,或叫做动态伪类,比如:link
、:active
、:visited
、:hover
。
:::success
伪类的标志是开头为冒号:
如a:hover{}
:::
| 选择器 | 描述 |
| —- | —- |
| 交互状态伪类 |
|
| :link | 匹配未曾访问的a链接。注意遵循 LVHA 的先后顺序,即::link — :visited — :hover — :active |
| :visited | 匹配已访问a链接 (存在于浏览器的历史纪录) |
| :hover | 鼠标悬浮时:当用户悬浮到一个元素之上的时候匹配。 |
| :active | 鼠标按下时:在用户激活元素的时候匹配,一般被用在 和