最新CSS3伪类和伪元素详解

第4章 伪类和伪元素

4.1结构伪类

E:first-child{},第一个元素

样式:

p:first-child {color: red; 
}
<div><p>Lorem ipsum</p><p>Dolor sit amet.</p>
</div>

4.1.1nth-*伪类

以计数为基础的,默认情况下,n代表从0开始的数字,以1递增(1,2,3等等),但是元素是从1开始的。

这里的*包括child和of-type等等

E:nth-*(n){},n表示1,2,3...

E:nth-*(2n){},n表示2,4,6...

E:nth-*(3n){},n表示3,6,9...

E:nth-*(n+1){},n表示1,2,3,4...

E:nth-*(2n+1){},n表示1,3,5...

E:nth-*(3n-1){},n表示2,5,8...

E:nth-*(even){},相当于2n,偶数

E:nth-*(odd){},相当于2n+1,奇数

nth-child与nth-of-type

E:nth-child表示按照当前父元素的所有子元素总数进行选择

E:nth-of-type表示按照特定元素进行选择

案例:

10个段落,CSS如下:

1.所有元素2n+1的底设为grey

2.div中的p中的2n字体设为红色

3.div中的p中的3n字体设为绿色

nth-last-child与nth-last-of-type

nth-child与nth-of-type类似,不同的是从最后一个元素开始计数。

<!DOCTYPE html>
<html><head><meta charset="utf-8"><title></title><style>div :nth-child(2n+1) {background-color: grey;}div p:nth-of-type(2n) {color: red;}div p:nth-of-type(odd) {color: green;}</style>
</head><body><div><span>span孙颖莎奥运已打52局</span><p>王楚钦回应球拍事件:自己是受害者,“我不想讨论”</p><p>王楚钦回应球拍事件:自己是受害者,“我不想讨论”</p><p>王楚钦回应球拍事件:自己是受害者,“我不想讨论”</p><p>王楚钦回应球拍事件:自己是受害者,“我不想讨论”</p><p>王楚钦回应球拍事件:自己是受害者,“我不想讨论”</p><span>span孙颖莎奥运已打52局</span><p>王楚钦回应球拍事件:自己是受害者,“我不想讨论”</p><p>王楚钦回应球拍事件:自己是受害者,“我不想讨论”</p><p>王楚钦回应球拍事件:自己是受害者,“我不想讨论”</p><p>王楚钦回应球拍事件:自己是受害者,“我不想讨论”</p><p>王楚钦回应球拍事件:自己是受害者,“我不想讨论”</p></div></body></html>

4.1.2 first-of-type、last-child、last-of-type

表示单个的选择,分别是某类型元素第一个,父元素中子元素最后一个,某类型元素最后一个。

4.1.1案例中,去掉CSS后,重写CSS:

1.p元素的第一个字体为red。

2.所有元素最后一个字体为green。

3.span类型最后一个元素字体为pink。

<!DOCTYPE html>
<html><head><meta charset="utf-8"><title></title><style>div p:first-of-type {color: red;}div :last-child {color: green;}div span:last-of-type {color: pink;}</style>
</head><body><div><span>span孙颖莎奥运已打52局</span><p>王楚钦回应球拍事件:自己是受害者,“我不想讨论”</p><p>王楚钦回应球拍事件:自己是受害者,“我不想讨论”</p><p>王楚钦回应球拍事件:自己是受害者,“我不想讨论”</p><p>王楚钦回应球拍事件:自己是受害者,“我不想讨论”</p><p>王楚钦回应球拍事件:自己是受害者,“我不想讨论”</p><span>span孙颖莎奥运已打52局</span><p>王楚钦回应球拍事件:自己是受害者,“我不想讨论”</p><p>王楚钦回应球拍事件:自己是受害者,“我不想讨论”</p><p>王楚钦回应球拍事件:自己是受害者,“我不想讨论”</p><p>王楚钦回应球拍事件:自己是受害者,“我不想讨论”</p><p>王楚钦回应球拍事件:自己是受害者,“我不想讨论”</p></div></body></html>

4.1.3 only-child,only-of-type

only-child表示没有任何兄弟元素

only-of-type表示没有相同类型的兄弟

4.2 其他伪类

4.2.1 target伪类

指向特定元素内部链接,URI指向唯一ID或指定锚点位置。

外部链接:

4.伪类target.html

<!DOCTYPE html>
<html><head><meta charset="utf-8"><title></title>
</head><body><a href="./4.target.html#my_id">Lorem</a>
</body></html>

同级目录下 4.target.html

<!DOCTYPE html>
<html><head><meta charset="utf-8"><title></title>
</head><body><h4>Lorem ipsum</h4><h4>Lorem ipsum</h4><h4>Lorem ipsum</h4><h4>Lorem ipsum</h4><h4>Lorem ipsum</h4><h4>Lorem ipsum</h4><h4>Lorem ipsum</h4><h4>Lorem ipsum</h4><h4>Lorem ipsum</h4><h4>Lorem ipsum</h4><h4>Lorem ipsum</h4><h4>Lorem ipsum</h4><h4 id="my_id" style="color: orange;">Lorem ipsum</h4><h4>Lorem ipsum</h4><h4>Lorem ipsum</h4>
</body></html>

将浏览器上下宽度小一点,必须有滚动条,则会发现页面跳转后,会自动滚动到目标位置。

内部链接:

点击前:

点击后:

代码:

<!DOCTYPE html>
<html><head><meta charset="utf-8"><title></title><style>.comment:target {background-color: #ddd;}</style>
</head><body><p><a href="#comment-03">最后的评论</a></p><div class="comment" style="border: 1px dotted;" id="comment-01"><p>Thanks for this scintillating example</p><p>N.E. Boddy, April 13</p></div><div class="comment" style="border: 1px dotted;" id="comment-02"><p>Meh.</p><p>Sum1, April 14</p></div><div class="comment" style="border: 1px dotted;" id="comment-03"><p>CSS3 is going to be great!</p><p>Joe Blogs, April 14</p></div>
</body></html>

4.2.2 empty伪类

选择没有子元素(包括文本节点)的元素

看案例:

<!DOCTYPE html>
<html>
<head><meta charset="utf-8"><title></title><style>td:empty {background-color: red;}</style>
</head>
<body><table border=""><thead><tr><td>第一列</td><td>第二列</td><td>第三列</td></tr></thead><tr><td></td><td>Lorem ipsum</td><td><span></span></td></tr></table>
</body>
</html>

4.2.3 root伪类与not伪类(基本不用,知道就行)

root伪类:给html一个较高的特殊度,设置html元素后不该被修改。

html:root { background-color: black }

not伪类:选择除了给定参数元素之外的所有元素。

E:not(F) {}

例子:div > :not(p) { color: red; }

4.3 伪元素

可以把样式应用到文档树中根本不存在的元素上。

::first-line 文本中的第一行

::first-letter 文本中的第一个字母

::after 元素之后添加

::before 元素之前

代码:

<!DOCTYPE html>
<html>
<head><meta charset="utf-8"><title></title><style>p::first-line {background-color: red;}p::first-letter {color: blue;font-weight: 600;}h1::before {content: "我是h1前面的添加的内容";color: chocolate;}p::after {content: "我是P后面的内容";color: brown;}</style>
</head>
<body><h1>|WWF's Mission Statement</h1><p>To stop the degradation of theplanet's natural environmentand to build a future in whichhumans live in harmony with nature,by; conserving the world's biological diversity, ensuring that the use of renewable natural resources issustainable, and promoting the reduction of pollution and wasteful consumption.|</p>
</body>
</html>

小结:UI元素状态,:selection冷门生僻,不学习。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/394242.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

探索下一代互联网协议:IPv6的前景与优势

探索下一代互联网协议&#xff1a;IPv6的前景与优势 文章目录 探索下一代互联网协议&#xff1a;IPv6的前景与优势**IPv6 的特点****IPv6的基本首部****IPv6的地址****总结** 互联网的核心协议&#xff1a;从IPv4到IPv6 互联网的核心协议IP&#xff08;Internet Protocol&#…

Docker Deskpot出现Docker Engine Stopped的解决历程

前提&#xff1a;我的操作系统是Win11家庭版, Docker Descktop下载的是最新版&#xff08;此时是4.30.0&#xff09; 出现了如图所示的问题“Docker Engine Stopped”,个人认为解决问题的关键是第四点&#xff0c;读者可以直接看第四点&#xff0c;如果只看第四点就成功解决&am…

python开发上位机 - PyCharm环境搭建、安装PyQt5及工具

目录 简介&#xff1a; 一、安装PyCharm 1、下载 PyCharm 2、PyCharm安装 1&#xff09;配置安装目录 2&#xff09;安装选项 3、问题及解决方法 二、安装PyQt5 1、打开 Pycharm&#xff0c;新建 Project 2、安装 pyqt5 3、安装很慢怎么办&#xff1f; 4、安装 pyq…

RHCSA第三次作业

磁盘管理及分区&#xff1a; [rootMYyyy ~]# fdisk /dev/sda [rootMYyyy ~]# lsblk NAME MAJ:MIN RM SIZE RO TYPE MOUNTPOINTS sda 8:0 0 10G 0 disk └─sda1 8:1 0 9G 0 part sdb 8:16 0 30G 0 disk sdc …

docker 部署 mysql8

命令 docker run --restartalways --name mysql8 -v /data/mysql/conf:/etc/mysql -v /data/mysql/data:/var/lib/mysql -v /data/mysql/log:/var/log -v /data/mysql/mysql-files:/var/lib/mysql-files -p 3308:3306 -e MYSQL_ROOT_PASSWORD123456 -d mysql:8 \解释 --rest…

基于SpringBoot框架的企业财务管理系统设计与实现(论文+源码)_kaic

摘 要 在快速增长的信息时代&#xff0c;每个企业都在紧随其后&#xff0c;不断改进其办公模式。与此同时&#xff0c;各家企业的传统管理模式也逐步发生变化&#xff0c;政府和企业都将需要一个更加自动化和现代化的财务管理系统。这能够便利员工之间的信息交流和公司的工作…

day22回溯学习记录第一天- - -代码随想录

77.组合 给定两个整数 n 和 k&#xff0c;返回范围 [1, n] 中所有可能的 k 个数的组合。 你可以按 任何顺序 返回答案。 思路:回溯的经典题目&#xff0c;回溯的整体结构类似于二叉树&#xff0c;如下图所示。据此图可知&#xff0c;采用递归是一种解决方法&#xff0c;在此引入…

定点数的运算

目录 1.定点数的移位运算 1.1算数移位 数学含义&#xff1a; 规律总结&#xff1a; 1.2逻辑移位 1.3循环移位 不带进位位 带进位位 2.定点数的加减运算 3.定点数的乘除运算 3.1原码 一位乘法 除法 3.2补码 一位乘法 除法 1.定点数的移位运算 1.1算数移位 数学…

Java日志框架

笔记学习原视频&#xff08;B站&#xff09;&#xff1a;全面深入学习多种java日志框架 目前常见日志框架有&#xff1a; JULLogbacklog4jlog4j2 目前常见的日志门面&#xff08;统一的日志API&#xff09;&#xff1a; JCLSlf4j 一、 老技术&#xff08;基本都弃用了&…

STM32——外部中断(EXTI)

目录 前言 一、外部中断基础知识 二、使用步骤 三、固件库实现 四、STM32CubeMX实现 总结 前言 外部中断&#xff08;External Interrupt&#xff0c;简称EXTI&#xff09;是微控制器用于响应外部事件的一种方式&#xff0c;当外部事件发生时&#xff08;如按键按下、传感器信号…

软件设计模式概述

模式的诞生 模式(Pattern)起源于建筑业而非软件业 模式之父——美国加利佛尼亚大学环境结构中心研究所所长Christopher Alexander&#xff08;克里斯托弗亚历山大&#xff09;博士 《A Pattern Language: Towns, Buildings, Construction》——253个建筑和城市规划模式。 他给出…

atsec增加Swift CSP评估资质

atsec信息安全评估员现已被Swift列为Swift客户安全计划&#xff08;CSP&#xff1a;Customer Security Programme&#xff09;认证评估员目录中的评估提供商&#xff0c;可以帮助全球金融机构评估其针对CSP强制性和咨询性控制的合规级别。在金融行业&#xff0c;Swift要求使用其…

MySQL的三大关键日志:Bin Log、Redo Log与Undo Log

MySQL的三大关键日志&#xff1a;Bin Log、Redo Log与Undo Log 1. Bin Log&#xff08;二进制日志&#xff09;2. Redo Log&#xff08;重做日志&#xff09;3. Undo Log&#xff08;回滚日志&#xff09; &#x1f496;The Begin&#x1f496;点点关注&#xff0c;收藏不迷路&…

C++现代教程四

float转string不带多余0 float a 1.2; std::tostring(a); // 1.200000 std::ostringstream strStream; strStream << a; // 1.2 if (!strStream.view().empty()) // 判定流有数据// 边框融合 float measureText(std::u8string text, FontTypes::Rectangle &recta…

科研绘图系列:R语言圆形条形图(circular barplot)

禁止商业或二改转载,仅供自学使用,侵权必究,如需截取部分内容请后台联系作者! 介绍 圆形条形图(circular barplot)是一种条形图,其中的条形沿着圆形而不是线性排列展示。这种图表的输入数据集与普通条形图相同:每个组(一个组即一个条形)需要一个数值。(更多解释请参…

IDEA2024.2重磅发布,更新完有4G!

JetBrains 今天宣布了其 IDE 家族版本之 2024.2 更新&#xff0c;其亮点是新 UI 现在已是默认设置&#xff0c;并且对 AI Assistant &#xff08;AI助手&#xff09;进行了几项改进。 安装密道 新 UI 的设计更加简约&#xff0c;可以根据需要以视觉方式扩展复杂功能。值得开发…

Linux 下查看 CPU 使用率

目录 一、什么是 CPU 使用率二、查看 CPU 利用率1、使用 top 查看2、用 pidstat 查看3、用 ps 查看4、用 htop 查看5、用 nmon 查看6、用 atop 查看7、用 glances 查看8、用 vmstat 查看9、用 sar 查看10、dstat11、iostat 三、总结 CPU 使用率是最直观和最常用的系统性能指标&…

QT生成.exe文件无法在未安装QT的电脑上运行的解决办法

在没有安装qt的电脑上运行qt生成的exe文件&#xff0c;提示&#xff1a; The application failed to start because no Qt platform plugin could be initialized 在网上找了很多办法&#xff0c;我尝试了 手动&#xff1a; 1、修改环境变量&#xff0c;2&#xff0c;添加pla…

C#开发编程软件下载安装

1、Visual Studio 2022社区版下载 2、开始安装 3、安装进行中 。。。。

【linux】curl命令用法

curl命令认识 curl命令其实在平常工作中就已经在使用了&#xff0c;但是一直没有系统看过&#xff0c;就在这记录下&#xff0c;以后要用的话&#xff0c;可以在这儿查阅。 curl命令写的更清楚一点其实是cURL&#xff08;client url&#xff0c;客户端URL或者command url命令…