• 技术文章 >web前端 >css教程

    css伪选择器学习之伪类选择器解析

    青灯夜游青灯夜游2022-08-03 11:27:03原创127
    在之前的文章《css伪选择器学习之伪元素选择器解析》中,我们学习了伪元素选择器,而今天我们详细了解一下伪类选择器,希望对大家有所帮助!

    伪类选择器

    伪类选择器 是一种允许通过未包含在HTML元素的状态信息来定位HTML元素的用法。伪类选择器 的具体用法就是向已有的选择器增加关键字,表示定位的HTML元素的状态信息。【推荐学习:css视频教程

    通过伪类,开发者可以设置元素的动态状态,例如悬停(hover)、点击(active)以及文档中不能通过其它选择器选择的元素(这些元素没有 ID 或 class 属性),例如第一个子元素(first-child)或者最后一个子元素(last-child)。

    例如:hover伪类选择器可以用来在用户将鼠标悬停在按钮上时改变按钮的颜色。如下示例代码所示:

    /* 所有用户指针悬停的按钮 */  
     button:hover {  
      color: blue;  
     }

    伪类的名称不区分大小写,但需要以冒号:开头。另外,伪类需要与 CSS 中的选择器结合使用,语法格式如下:

    选择器:伪类 {  
      属性 : 属性值;  
     }

    伪类选择器 的具体语法格式为 :伪类,这里一定不要忘记 :

    CSS 中提供了各种各样的伪类,如下表所示:

    选择器例子例子描述
    :activea:active匹配被点击的链接
    :checkedinput:checked匹配处于选中状态的 <input> 元素
    :disabledinput:disabled匹配每个被禁用的 <input> 元素
    :emptyp:empty匹配任何没有子元素的 <p> 元素
    :enabledinput:enabled匹配每个已启用的 <input> 元素
    :first-childp:first-child匹配父元素中的第一个子元素 <p>,<p> 必须是父元素中的第一个子元素
    :first-of-typep:first-of-type匹配父元素中的第一个 <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>, <p> 必须是父元素中的最后一个子元素
    :last-of-typep:last-of-type匹配父元素中的最后一个 <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>
    :nth-of-type(n)p:nth-of-type(2)匹配父元素的第二个子元素 <p>
    :only-of-typep:only-of-type匹配父元素中唯一的 <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匹配元素的根元素,在 HTML 中,根元素永远是 HTML
    :target#news:target匹配当前活动的 #news 元素(单击包含该锚名称的 URL)
    :validinput:valid匹配所有具有有效值的 <input> 元素
    :visiteda:visited匹配所有已经访问过的链接

    伪类选择器的分类

    CSS 版本从第一版本发展到第三版本,提供的伪类选择器 的数量已经很庞大了。尤其CSS3版本新增了大量的伪类选择器

    伪类选择器 的数量这么多,为了更好地梳理伪类选择器 ,我们可以按照用途的不同分为如下 5 种类型:

    1、用户行为伪类--动态伪类选择器

    之所以称为动态伪类选择器,是因为它们根据条件的改变匹配元素,是相对于文档的固定状态来说的。随着JavaScript广泛用于修改文档内容和元素状态,动态选择器和静态选择器之间的界限越来越模糊,不过,动态伪类选择器仍然是一类比较特别的选择器。

    :link选择器匹配超链接,:visited选择器匹配用户已经访问过得超链接。

    使用:visited选择器可以应用到链接元素的属性不多。你可以改变颜色和字体,不过仅此而已。

    提示::visited选择器匹配用户在所有页面访问过的href属性为URL的任意链接,而不只是你的页面。:visited最常见的用法就是针对已访问的链接应用某种样式,从而让它们跟未访问的链接有所区别。比如我们看新闻,看过的新闻和没有看过的新闻在首页列表呈现的状态是不一样的,便于我们区分。

    :hover 选择器

    :hover选择器匹配用户鼠标悬停在其上的任意元素。

    :active 选择器

    :active选择器匹配当前被用户激活的元素(一般情况下为鼠标点击该元素)。

    :focus 选择器

    :focus选择器匹配获得焦点的元素,常用于 input 元素。

    2、结构性伪类选择器

    使用结构性伪类选择器能够根据元素在文档中的位置选择元素。这类选择器都有一个冒号字符前缀(:),例如:empty。他们可以单独使用,也可以跟其他选择器组合使用,如p:empty。

    结构伪类选择器类选择器包含的内容如下表所示:

    伪类选择器作用
    selector:first-child用来定位一组兄弟元素中的第一个元素
    selector:last-child用来定位一组兄弟元素中的最后一个元素
    selector:nth-child(n)用来定位一组兄弟元素中的第n个元素
    selector:nth-last-child(n)用来定位一组兄弟元素中倒序方式的第n个元素
    selector:first-of-type用来定位一组同类型的兄弟元素中的第一个元素
    selector:last-of-type用来定位一组同类型的兄弟元素中的最后一个元素
    selector:nth-of-type(n)用来定位一组同类型的兄弟元素中的第n个元素
    selector:nth-last-of-type(n)用来定位一组同类型的兄弟元素中倒序方式的第n个元素
    selector:only-child用来定位一个没有任何兄弟元素的元素
    selector:only-of-type用来定位一个没有任何同类型兄弟元素的元素
    selector:empty用来定位一个没有子级元素的元素,并且该元素也没有任何文本内容
    selector:root用来定位 HTML 页面中的根元素(<html>

    CSS中的结构伪类选择器是根据HTML页面中元素之间的关系来定位HTML元素,从而减少对HTML元素的id属性和class属性的依赖。

    :first-child与:last-child

    :first-child伪类用来定义一组兄弟元素的第一个元素而:last-child伪类则是定位一组兄弟元素的最后一个元素。

    如下示例代码展示了:first-child伪类和:last-child伪类的用法:

    HTML结构如下:

    <ul>
        <li>涂山红红</li>
        <li>涂山苏苏</li>
        <li>涂山蓉蓉</li>
        <li>涂山雅雅</li>
    </ul>

    CSS代码如下:

    li:first-child {
        color: red;
    }
    li:last-child {
        color: blue;
    }

    代码运行结果如下图所示:

    1.png

    :first-child 伪类可以使用:nth-child(n)伪类改写为:nth-child(1),而:last-child伪类可以使用:nth-last-child(n)伪类改写为:nth-last-child(1)

    :first-child伪类和:last-child伪类经常会引起误解。例如 li:first-child 是用来定位所有<li>元素中第一个作为子级元素的,而不是定位<li>元素的第一个子级元素。

    :first-of-type与:last-of-type

    :first-of-type伪类和:last-of-type伪类一个用于定位一组元素中的第一个兄弟元素,一个用来定位最后一个。

    如下示例代码展示了:first-of-type伪类和:last-of-type伪类的用法:

    HTML结构如下:

    <h3>狐妖小红娘</h3>
    <p>涂山红红</p>
    <p>涂山苏苏</li>

    CSS代码如下:

    p:first-of-type {
        color: red;
    }
    
    p:last-of-type {
        color: blue;
    }

    代码运行结果如下图所示:

    2.png

    :first-of-type伪类与:last-of-type伪类的用法一定要和:first-child伪类与:last-child伪类的用法区分开。以:first-of-type伪类和:first-child伪类为例来说明:

    如果将上述示例代码中的:first-of-type伪类改写为:first-child伪类的话,将不会生效。

    :nth-child(n)与:nth-last-child(n)

    :nth-child(n)伪类和:nth-last-child(n)伪类都是CSS3中新增的选择器,这两个选择器的用法基本上是一致的。区别在于:nth-last-child(n)伪类是倒序方式定位元素,也就是说,:nth-last-child(n)伪类是从一组元素的结尾开始的。

    接下来,主要以:nth-child(n)伪类为例进行讲解。:nth-child(n)伪类中的n参数的含义具有3种情况:

    如下示例代码展示了:nth-child(n)伪类(实现表格隔行换色效果)的用法:

    <!DOCTYPE html>
    <html>
    
    <head>
        <meta charset="UTF-8">
        <meta http-equiv="X-UA-Compatible" content="IE=edge">
        <meta name="viewport" content="width=device-width, initial-scale=1.0">
        <title>nth-child伪类</title>
        <style>
            table {
                border-collapse: collapse;
                border-spacing: 0;
                width: 100%;
            }
    
            th,
            td {
                border-top: 1px solid lightcoral;
                text-align: center;
            }
    
            /* 最后一行单元格在底部增加一个边框效果 */
            tr:last-child td {
                border-bottom: 1px solid lightcoral;
            }
    
            /* 实现隔行换色 */
            tr:nth-child(even) {
                background-color: aquamarine;
            }
        </style>
    </head>
    
    <body>
        <table>
            <tr>
                <th>姓名</th>
                <th>区域</th>
            </tr>
            <tr>
                <td>梵云飞</td>
                <td>西西域</td>
            </tr>
            <tr>
                <td>欢都落兰</td>
                <td>南国</td>
            </tr>
            <tr>
                <td>石宽</td>
                <td>北山</td>
            </tr>
            <tr>
                <td>涂山红红</td>
                <td>涂山</td>
            </tr>
        </table>
    </body>
    
    </html>

    代码运行结果如下图所示:

    3.png

    :nth-child(n)伪类的n参数用法中比较复杂的是使用(an+b)公式用法,如下示例列举了一些公式用法:

    :nth-child(n)伪类与:nth-last-child(n)伪类和:nth-of-type(n)伪类与:nth-last-of-type(n)伪类的区别,类似于:first-of-type伪类与:last-of-type伪类和:first-child伪类与:last-child伪类的区别。

    :empty

    :empty伪类是用来定位没有任何子级元素或文本内容的元素,其中文本内容包含了空白。但是HTML的注释是不影响:empty伪类定位元素的。

    如下示例代码展示了:empty伪类的用法:

    <!DOCTYPE html>
    <html>
    
    <head>
        <meta charset="UTF-8">
        <meta http-equiv="X-UA-Compatible" content="IE=edge">
        <meta name="viewport" content="width=device-width, initial-scale=1.0">
        <title>empty伪类</title>
        <style>
            body {
                /* 开启flex布局 */
                display: flex;
            }
    
            .box {
                background: pink;
                height: 80px;
                width: 80px;
                margin: 0 20px;
            }
    
            .box:empty {
                background: lime;
            }
        </style>
    </head>
    
    <body>
        <div></div>
        <div>这个元素的背景是粉色的</div>
        <div>
            <!-- 这是一个注释 -->
        </div>
    </body>
    
    </html>

    代码运行结果如下图所示:

    4.png

    :root

    CSS中的:root伪类选择器比较简单,它代表的就是<html>元素。

    如下代码展示的:root伪类的用法:

    :root {
        height: 100vh;
        width: 100vw;
        background-color: dodgerblue;
    }

    代码运行结果如下图所示:

    5.png

    3、UI元素状态伪类选择器

    使用UI伪类选择器可以根据元素的状态匹配元素,下方列表将简单总结这类选择器:

    选择器说明
    :enabled选择启用状态的元素
    :disabled选择禁用状态的元素
    :checked选择被选中的input元素(只用于单选按钮和复选框)
    :default选择默认元素
    :valid根据输入验证选择有效或者无效的input元素
    :in-range/:out-of-range选择在制定范围之内或者职位受限的input元素
    :required/:optional根据是否允许:required属性选择input元素

    4、输入伪类选择器

    关于表单输入的伪类,主要介绍三种常用的,具体如下:

    :enabled和:disabled

    :enabled:disabled一这组伪类选择器分别表示禁用状态与可用状态,这组为了使完全对立的。

    :enabled伪类的实际用处并不大,因为大多元素默认都是可用的,所以写不写意义并不大。

    如下代码展示了:enabled:disabled的用法:

    <!DOCTYPE html>
    <html>
    
    <head>
      <meta charset="UTF-8">
      <meta http-equiv="X-UA-Compatible"
            content="IE=edge">
      <meta name="viewport"
            content="width=device-width, initial-scale=1.0">
      <title>:enabled和:disabled的用法</title>
      <style>
        input:enabled {
          outline: none;
        }
    
        input:disabled {
          /* 禁用状态背景为灰色 */
          background-color: gray;
        }
      </style>
    </head>
    
    <body>
      <input type="text"
             placeholder="可用状态">
      <input type="text"
             disabled
             placeholder="禁用状态">
    </body>
    
    </html>

    代码运行结果如下所示:

    1.png

    由上图我们看到禁用状态的<input>的背景颜色为灰色。

    :read-only和:read-write

    :read-only:read-write一这组伪类选择器分别表示只读和可写状态,同样的:read-write也很鸡肋,因为默认就是可读写,示例代码如下所示:

    <!DOCTYPE html>
    <html>
    
    <head>
      <meta charset="UTF-8">
      <meta http-equiv="X-UA-Compatible"
            content="IE=edge">
      <meta name="viewport"
            content="width=device-width, initial-scale=1.0">
      <title>:read-only和:read-write</title>
      <style>
        input:read-write {
          outline: none;
        }
    
        /* 只读状态 */
        input:read-only {
          color: red;
          outline: none;
        }
      </style>
    </head>
    
    <body>
      <input type="text"
             value="读写状态">
      <input type="text"
             readonly
             value="只读状态">
    </body>
    
    </html>

    代码运行结果如下所示:

    2.png

    我们可以看到,只读的<input>的文字颜色为红色。

    :checked

    :checked伪类可以说是众多伪类选择器中使用频率很高的一个伪类选择器,该选择器表示选中的状态,就比如下面这个例子:

    <!DOCTYPE html>
    <html>
    
    <head>
      <meta charset="UTF-8">
      <meta http-equiv="X-UA-Compatible"
            content="IE=edge">
      <meta name="viewport"
            content="width=device-width, initial-scale=1.0">
      <title>checked伪类</title>
      <style>
        input:checked {
          /* 为选中的增加阴影 */
          box-shadow: 2px 2px 2px 2px lightcoral;
        }
      </style>
    </head>
    
    <body>
      <input type="checkbox">
      <input type="checkbox"
             checked>
    </body>
    
    </html>

    3.png

    关于:checked伪类,最佳实践是配合<label>元素来实现,现在我们就通过:checked<label>元素来实现一个开关的效果。

    示例代码如下:

    <!DOCTYPE html>
    <html>
    
    <head>
      <meta charset="UTF-8">
      <meta http-equiv="X-UA-Compatible"
            content="IE=edge">
      <meta name="viewport"
            content="width=device-width, initial-scale=1.0">
      <title>开关</title>
      <style>
        [type="checkbox"] {
          width: 44px;
          height: 26px;
          position: absolute;
          opacity: 0;
          pointer-events: none;
        }
    
        /* 开关样式 */
        .cs-switch {
          display: inline-block;
          width: 44px;
          height: 26px;
          border: 2px solid;
          border-radius: 26px;
          background-color: currentColor;
          box-sizing: border-box;
          color: silver;
          transition: all .2s;
          cursor: pointer;
        }
    
        .cs-switch::before {
          content: "";
          display: block;
          width: 22px;
          height: 22px;
          border-radius: 50%;
          background-color: #fff;
          transition: margin-left .2s;
        }
    
    
        :checked+.cs-switch {
          color: blueviolet;
        }
    
        /* 选中移动 */
        :checked+.cs-switch::before {
          margin-left: 18px;
        }
    
        /* 禁用状态 */
        :disabled+.cs-switch {
          opacity: .4;
          cursor: not-allowed;
        }
      </style>
    </head>
    
    <body>
      <!-- 普通状态 -->
      <input type="checkbox"
             id="switch">
      <label
             for="switch"></label>
      <!-- 选中状态 -->
      <input type="checkbox"
             id="switch1"
             checked>
      <label
             for="switch1"></label>
      <!-- 禁用状态 -->
      <input type="checkbox"
             id="switch2"
             disabled>
      <label
             for="switch2"></label>
      <!-- 选中禁用状态 -->
      <input type="checkbox"
             id="switch3"
             checked
             disabled>
      <label
             for="switch3"></label>
    </body>
    
    </html>

    运行效果如下所示:

    4.png

    5、逻辑组合伪类

    :not()否定的伪类

    :not()的巨大的用处在于告别重置的问题;

    重置web中的样式,就好比我们在项目中经常使用到的:添加.active类名来控制样式的显示与隐藏/改变样式,往常的写法都是:

    .cs_li {
    	display: none;
    }
    .cs_li.active {
    	display: block;
    }

    而我们可以使用:not()伪类,可以更好的实现:

    .cs_li:not(.active) {
    	display: none;
    }

    在列表中的设置<li>的边框时也可使用其:not()

    .cs_li:not(:nth-of-type(5n)){
    	margin-right: 10px; // 除5的倍数项都设置右边的外边距
    }

    :is()的作用是简化选择器

    平时我们开发中经常会用到类似下面的语法:

    .cs_li_a > img,
    .cs_li_b > img,
    .cs_li_c > img {
    	display: none;
    }

    使用:is()简化可写成:

    :is(.cs_li_a, .cs_li_b, .cs_li_c) > img {
    	display: none;
    }

    还有一种嵌套之间的关系,相互嵌套,交叉组合得出结论;如下方所示

    ol ol li,
    ol ul li, 
    ul ul li,
    ul ol li {
    	margin-left: 20px;
    }

    使用:is()伪类强化,则只需要几行代码:

    :is(ol, ul) :is(ol, ul) li{
    	margin-left: 20px;
    }

    :where()

    :where()与上方的:is()相同,唯一不同的是级别永远为0,也不受括号里面的表达式影响;

    使用的方法与:is()完全相同,但优先级永远是0;底下的括号中的优先级完全被忽略,俩句是同一个优先级,并且级别等同于.conten选择器

    :where(.article, section) .conten {}
    :where(#article, #section) .conten {

    (学习视频分享:web前端入门

    以上就是css伪选择器学习之伪类选择器解析的详细内容,更多请关注php中文网其它相关文章!

    声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn核实处理。
    专题推荐:伪元素 选择器 伪类 css
    上一篇:一起聊聊CSS盒子大小与内外边距及边框的关系 下一篇:介绍下CSS盒子模型以及box-sizing属性
    VIP课程(WEB全栈开发)

    相关文章推荐

    • 【活动】充值PHP中文网VIP即送云服务器• css3新增伪类选择器有哪些• 详解CSS中的基本选择器,并聊聊选择器优先级• CSS布局属性控制元素的隐藏与显示• CSS利用float属性控制div左右浮动详解• CSS标准盒模型与浮动的使用总结• CSS中什么是层级选择器?怎么用?
    1/1

    PHP中文网