2.1 基本选择器

2.1.1 标签选择器

直接使用元素标签进行选择

p{color:red;} 权重1

2.1.2 类选择器

通过元素的类名,来选择元素,一个元素可以有多个类名,都代表这个元素类名是元素class属性中的属性值,例如

.sum{} => 此选择器的权重为10

2.1.3 id选择器

通过元素的id名,来选择元素,类名是元素id属性中的属性值,例如

#sum{} => 此选择器的权重为100

2.1.4 通配符选择器

通过*选择全部元素,包括根元素 *{} => 权重小于1,可以被覆盖

2.2 并集选择器

你可以对选择器进行分组,这样,被分组的选择器就可以分享想相同的声明。用逗号被需要分组的选择器分开。在下面的例子中,我们对所有的标题元素进行了分组。所有的标题元素都是绿色的。

1
2
3
h1,h2,h3,h4,h5,h6{
color:green;
}

2.3 交集选择器

两种属性同属一个元素的时候,我们可以使用交集选择器来进行元素的准确选择

1
2
3
4
<p class='name1 name2' id='id1'></p>
p.name1{}
p#id1{}
.name1.name2{}

2.4 派生(后代)选择器

  • 通过依据元素在其位置的上下文关系来定义样式,你可以使标记更加简洁,用空格隔开列表中的strong元素变为斜体字,而不是通常的粗体字,可以这样定义一个派生选择器
  • 后台选择器尽量不要超过3个,没有必要把每一个层级都写出来,只需要写出关键节点极客
1
2
3
4
5
6
7
8
9
10
li strong{
font-style:italic;
font-weight:normal;
}

<ol>
<li>
<strong>我是斜体字。这个因为strong元素位于li元素内。</stong>
</li>
</ol>

2.5 子代选择器

与后代选择器相比,子元素选择器只有选择作为某元素子元素,符号为大括号

1
2
3
h1 > strong {color:red;}

<h1>This is<strong>very</strong> important.</h1>

2.6 相邻兄弟选择器

相邻兄弟选择器可选择紧接在另一元素后的元素,且二者有相同父元素

1
2
3
h1+p{
margin-top:50px;
}

2.7 属性选择器

对带有指定属性的html元素设置样式 权重10

可以为拥有指定html元素设置样式,而不仅限于class和id属性

下面的例子为title属性的所有元素设置样式

1
[title]{color:red;}

属性和值选择器
下面的例子为title=’wjw’的所有元素设置样式

1
[title=wjw]{color:red;}

设置表单的样式

1
input[type='text']{width:150px;display:block;background:yellow}

2.8 伪装选择器

  • a:link{color:#ff000} // 未访问的链接
  • a:visited{color::#ff000} // 已访问的链接
  • a:hover{color:#ff000} // 鼠标移动到链接上
  • a:active{color:#ff000} //选定的链接

    10<权重<11

选择器
示例 示例描述 CSS版本
.class .demo 选择 class=”demo” 的所有元素 1
#id #firstname 选择 id=”firstname” 的所有元素 1
* * 选择所有元素 2
element p 选择所有

元素

1
element,element div,p 选择所有
元素和所有

元素

1
element element div p 选择
元素内部的所有

元素

1
element>element div>p 选择父元素为
元素的所有

元素

2
element+element div+p 选择紧接在
元素之后的所有

元素

2
[attribute] [target] 选择带有 target 属性所有元素 2
[attribute=value] [target=_blank] 选择 target=”_blank” 的所有元素 2
[attribute~=value] [title~=flower] 选择 title 属性包含单词 “flower” 的所有元素 2
[[attribute =value]](https://www.html.cn/book/css/selectors/attribute/att7.htm) [lang|=en] 选择 lang 属性值以 “en” 开头的所有元素
:link a:link 选择所有未被访问的链接 1
:visited a:visited 选择所有已被访问的链接 1
:active a:active 选择活动链接 1
:hover a:hover 选择鼠标指针位于其上的链接 1
:focus input:focus 选择获得焦点的 input 元素 2
:first-letter p:first-letter 选择每个

元素的首字母

1
:first-line p:first-line 选择每个

元素的首行

1
:first-child p:first-child 选择属于父元素的第一个子元素的每个

元素

2
:before p:before 在每个

元素的内容之前插入内容

2
:after p:after 在每个

元素的内容之后插入内容

2
:lang(language) p:lang(it) 选择带有以 “it” 开头的 lang 属性值的每个

元素

2
element1~element2 p~ul 选择前面有

元素的每个

    元素

3
[attribute^=value] a[src^=”https”] 选择其 src 属性值以 “https” 开头的每个 元素 3
[attribute$=value] a[src$=”.pdf”] 选择其 src 属性以 “.pdf” 结尾的所有 元素 3
[attribute*=value] a[src*=”abc”] 选择其 src 属性中包含 “abc” 子串的每个 元素 3
:first-of-type p:first-of-type 选择属于其父元素的首个

元素的每个

元素

3
:last-of-type p:last-of-type 选择属于其父元素的最后

元素的每个

元素

3
:only-of-type p:only-of-type 选择属于其父元素唯一的

元素的每个

元素

3
:only-child p:only-child 选择属于其父元素的唯一子元素的每个

元素

3
:nth-child(n) p:nth-child(2) 选择属于其父元素的第二个子元素的每个

元素

3
:nth-last-child(n) p:nth-last-child(2) 同上,从最后一个子元素开始计数 3
:nth-of-type(n) p:nth-of-type(2) 选择属于其父元素第二个

元素的每个

元素

3
:nth-last-of-type(n) p:nth-last-of-type(2) 同上,但是从最后一个子元素开始计数 3
:last-child p:last-child 选择属于其父元素最后一个子元素每个

元素

3
:root :root 选择文档的根元素 3
:empty p:empty 选择没有子元素的每个

元素(包括文本节点)

3
:target #news:target 选择当前活动的 #news 元素 3
:enabled input:enabled 选择每个启用的 元素 3
:disabled input:disabled 选择每个禁用的 元素 3
:checked input:checked 选择每个被选中的 元素 3
:not(selector) :not(p) 选择非

元素的每个元素

3
::selection ::selection 选择被用户选取的元素部分 3
:out-of-range :out-of-range 匹配值在指定区间之外的input元素 3
:in-range :in-range 匹配值在指定区间之内的input元素 3
:read-write :read-write 用于匹配可读及可写的元素 3
:read-only :read-only 用于匹配设置 “readonly”(只读) 属性的元素 3
:optional :optional 用于匹配可选的输入元素 3
:required :required 用于匹配设置了 “required” 属性的元素 3
:valid :valid 用于匹配输入值为合法的元素 3
:invalid :invalid 用于匹配输入值为非法的元素 3