CSS选择器详解与记录

要使用css对HTML页面中的元素实现一对一,一对多或者多对一的控制,这就需要用到CSS选择器。

一.简单选择器

通用选择器 ("*")

*{代码块}    //选中页面中所有元素

ID 选择器 ("#")

#id名{代码块}    //选中对应id属性值的元素

类选择器 (".")

.类名{代码块}    //根据类名来选择

元素选择器("name")

标签名{}    //将css应用到某个标签

二.复合选择器

复合选择器其实就是简单选择器与某些标识符复合使用

后代选择器 (空格)

简单选择器 简单选择器    //选择特定元素或元素组的后代,区别于子代

子选择器(”>")

简单选择器 简单选择器    //子选择器仅是指它的直接后代

相邻兄弟选择器 (”+")

简单选择器+简单选择器    //指定元素的相邻的同级元素,必须相邻,且在被选择选择器的下面

通用兄弟选择器 (”~")

简单选择器~简单选择器    //指定元素的所有指定同级元素

并集选择器","

简单选择器,简单选择器    //同时多个选中对应选择器的元素

三.属性选择器

[属性名]{代码块}               //选择具有某属性的所有元素

[属性名=属性值]{代码块}        //选择属性为指定值的所有元素

[属性名^="字符串"]{代码块}     //选择属性的值以指定字符串开头的所有元素

[属性名$="字符串"]{代码块}     //选择属性的值以指定字符串结尾的所有元素

[属性名*="字符串"]{代码块}     //选择属性的值包含指定字符串的所有元素
d
[属性名~="字符串"]{代码块}     //选择属性的值包含以空格分隔的指定字符串的所有元素,即指定的字符串与                    
                               其他单词之间有空格分隔

[属性名|="字符串"]{代码块}     //选择属性的值等于指定字符串或以"字符串-"开头的所有元素

四.伪类选择器

选择器例子例子描述
:activea:active选择活动的链接。
:checkedinput:checked选择每个被选中的 <input> 元素。
:disabledinput:disabled选择每个被禁用的 <input> 元素。
:emptyp:empty选择没有子元素的每个 <p> 元素。
:enabledinput:enabled选择每个已启用的 <input> 元素。
:first-childp:first-child选择作为其父的首个子元素的每个 <p> 元素。
:first-of-typep:first-of-type选择作为其父的首个 <p> 元素的每个 <p> 元素。
:focusinput:focus选择获得焦点的 <input> 元素。
:hovera:hover选择鼠标悬停其上的链接。
:in-rangeinput:in-range选择具有指定范围内的值的 <input> 元素。
:invalidinput:invalid选择所有具有无效值的 <input> 元素。
:lang(language)p:lang(it)选择每个 lang 属性值以 "it" 开头的 <p> 元素。
:last-childp:last-child选择作为其父的最后一个子元素的每个 <p> 元素。
:last-of-typep:last-of-type选择作为其父的最后一个 <p> 元素的每个 <p> 元素。
:linka:link选择所有未被访问的链接。
:not(selector):not(p)选择每个非 <p> 元素的元素。
:nth-child(n)p:nth-child(2)选择作为其父的第二个子元素的每个 <p> 元素。
:nth-last-child(n)p:nth-last-child(2)选择作为父的第二个子元素的每个<p>元素,从最后一个子元素计数。
:nth-last-of-type(n)p:nth-last-of-type(2)选择作为父的第二个<p>元素的每个<p>元素,从最后一个子元素计数
:nth-of-type(n)p:nth-of-type(2)选择作为其父的第二个 <p> 元素的每个 <p> 元素。
:only-of-typep:only-of-type选择作为其父的唯一 <p> 元素的每个 <p> 元素。
:only-childp:only-child选择作为其父的唯一子元素的 <p> 元素。
:optionalinput:optional选择不带 "required" 属性的 <input> 元素。
:out-of-rangeinput:out-of-range选择值在指定范围之外的 <input> 元素。
:read-onlyinput:read-only选择指定了 "readonly" 属性的 <input> 元素。
:read-writeinput:read-write选择不带 "readonly" 属性的 <input> 元素。
:requiredinput:required选择指定了 "required" 属性的 <input> 元素。
:rootroot选择元素的根元素。
:target#news:target选择当前活动的 #news 元素(单击包含该锚名称的 URL)。
:validinput:valid选择所有具有有效值的 <input> 元素。
:visiteda:visited选择所有已访问的链接。

五.伪元素选择器

选择器例子例子描述
::afterp::after在每个 <p> 元素之后插入内容。
::beforep::before在每个 <p> 元素之前插入内容。
::first-letterp::first-letter选择每个 <p> 元素的首字母。
::first-linep::first-line选择每个 <p> 元素的首行。
::selectionp::selection选择用户选择的元素部分。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

ManiacM

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值