【css3】02-css3新特性之选择器篇

目录

[1 属性选择器](#1 属性选择器)

[2 结构伪类选择器](#2 结构伪类选择器)

[3 其他选择器](#3 其他选择器)

:target和::selection

::first-line和::first-letter

[4 伪类和伪元素的区别](#4 伪类和伪元素的区别)

伪类(Pseudo-classes)

伪元素(Pseudo-elements)

伪类和伪元素的区别


1 属性选择器

☞ 属性选择器:

  • 属性名=值 {}
  • 属性名 {} 匹配对应的属性即可
  • 属性名\^=值 {} 以值开头
  • 属性名\*=值 {} 包含
  • 属性名$=值 {} 以值结束

样例:

复制代码
<!DOCTYPE html>
<html lang="en">

<head>
	<meta charset="UTF-8">
	<title>Document</title>
	<style type="text/css">
		/* p 标签 class属性值以o结尾 */
		/* p[class$="o"] {
			color: red;
		} */

		/* p标签下匹配对应的属性class */
		/* p[class] {
			color: red;
		} */

		/* p标签下  class属性值以o开头 */
		p[class^="o"] {
			color: red;
		}

		/* p标签下  class属性值包含 */
		p[class*="o"] {
			color: red;
		}
	</style>
</head>

<body>
	<div class="one">文字</div>
	<p class="one">段落</p>
	<p class="two">段落2</p>
</body>

</html>

2 结构伪类选择器

☞ 结构伪类选择器:

  • :first-child {} 选中父元素中第一个子元素
  • :last-child {} 选中父元素中最后一个子元素
  • :nth-child(n) {} 选中父元素中正数第n个子元素
  • :nth-last-child(n) {} 选中父元素中倒数第n个子元素

样例说明:li:first-child {} 假若li不是父元素里的第一个元素,则不会生效

复制代码
<head>
	<meta charset="UTF-8">
	<title>Document</title>
	<style type="text/css">
		/* li {
			color: red;
		}
		 */

		/* 第一个子元素是li */
		/* li:first-child {
			 color: red;
		}
		
		li:last-child {
			color: red;
		} */

		/* li:nth-child(3) {
			color: red;
		} */

		/* li:nth-last-child(3) {
			color: red;
		} */

		li:nth-child(odd) {
			color: red;
		}
	</style>
</head>

<body>

	<ul>
		<li>1</li>
		<li>2</li>
		<li>3</li>
		<li>4</li>
		<li>5</li>
		<li>6</li>
		<li>7</li>
	</ul>
</body>

备注:

1、n 的取值大于等于0时,n 可以设置预定义的值:

  • odd表示选中奇数位置的元素
  • even表示选中偶数位置的元素

2、 n 可以是一个表达式:

an+b的格式

3 其他选择器

☞ 其他选择器:

  • :target 被锚链接(a标签)指向的时候会触发该选择器
  • ::selection 当(文本...)被鼠标选中的时候显示该样式
  • ::first-line 选中第一行
  • ::first-letter 选中第一个字符

:target和::selection

效果:1 是run执行后的初始页面

2 是点击了"找第5行的p"触发了:target样式效果

3 是鼠标选中文字,触发::selection 样式效果

代码:

复制代码
<head>
	<meta charset="UTF-8">
	<title>Document</title>
	<style type="text/css">
		/* 被锚链接指向的时候会触发该选择器 */
		p:target {
			color: red;
		}


		/* 当使用鼠标选中的时候样式 */
		p::selection {
			color: red;
			background-color: pink;
		}
	</style>
</head>

<body>

	<p>文字</p>
	<p>文字</p>
	<p>文字</p>
	<p>文字</p>
	<p id="test">文字</p>
	<p>文字</p>
	<p>文字</p>
	<p>文字</p>

	<a href="#test">找第5行的p</a>
</body>

::first-line和::first-letter

样例:第一行设置为红色;第一个字母设置为蓝色

代码:

复制代码
<head>
	<meta charset="UTF-8">
	<title>Document</title>
	<style type="text/css">
		.one {
			width: 200px;
			height: 200px;
			border: 1px solid red;
			word-break: break-all;
		}

		.one:first-line {
			color: red;
		}

		.one:first-letter {
			font-size: 50px;
			color: blue;
		}
		
/* 
		.one::before {
			content: "";
			width: 100px;
			height: 100px;
			background-color: pink;
			display: block;
		}
 */

	</style>
</head>
<body>
	<div class="one">
		asdfadfafdasfasfdasdfafdasfdadsfasdfafdasdfasdfasdfafdadfafdasdfajsdflkajlfkjafdlkjaslfjalkdsfjalsjfalkdsjfalsfd
	</div>
</body>

4 伪类和伪元素的区别

在CSS3中,伪类(Pseudo-classes)和伪元素(Pseudo-elements)是两个不同的概念,尽管它们有时候在名称和用法上可能有些相似,但它们各自有不同的目的和功能。

伪类(Pseudo-classes)

伪类用于选择处于特定状态的元素。它们以冒号(:)开头,并且用于选择页面上处于特定状态的元素,而不是基于元素的名称、类、ID或属性。例如:

  • :hover:用户悬停在元素上时的样式。
  • :active:元素被激活(如鼠标点击但尚未释放)时的样式。
  • :visited:用户已访问的链接的样式。
  • :first-child:作为其父元素的第一个子元素的样式。
  • :nth-child(n):作为其父元素的第n个子元素的样式。
  • :odd:even:用于选择列表中奇数或偶数位置的元素(与 :nth-child(odd):nth-child(even) 类似)。

伪元素(Pseudo-elements)

伪元素用于在元素的内容前后插入内容,或者选择元素的特定部分。它们也以冒号(:)开头,但紧接着是一个双冒号(::),以区分伪类和伪元素。但在CSS2.1和更早的规范中,伪元素仅使用单冒号。为了向后兼容,大多数浏览器在单冒号和双冒号之间都有很好的支持。但在CSS3中,推荐使用双冒号来明确表示伪元素。

一些常见的伪元素包括:

  • ::before:在元素的内容之前插入内容。
  • ::after:在元素的内容之后插入内容。
  • ::first-letter:选择文本块的首字母。
  • ::first-line:选择文本块的第一行。
  • ::selection:用户用鼠标或其他指针设备选择的元素部分。

伪类和伪元素的区别

  • 用途:伪类用于选择处于特定状态的元素,而伪元素用于在元素的内容前后插入内容或选择元素的特定部分。
  • 语法 :虽然两者都以冒号开头,但伪元素通常使用双冒号(::),以与伪类区分。
  • 元素数量 :伪类可以应用于一个或多个元素,而伪元素(如::before::after)通常只与一个元素关联。
  • 对DOM的影响:伪类不添加新的元素到DOM树中,而伪元素则实际上在DOM树中添加了一个虚拟的元素。
相关推荐
Csvn3 小时前
OpenSpec 详细使用教程
前端
王莎莎-MinerU3 小时前
MinerU 深度技术解析:从架构原理到生产部署的全面指南
css·人工智能·自然语言处理·架构·ocr·个人开发
之歆3 小时前
Day19_LESS 完全指南——从入门到工程实践
前端·css·less
云水一下4 小时前
HTML5 从入门到精通:实战收官——从零搭建完整静态网站,综合运用所有知识
前端·html5
不总是4 小时前
Windows 系统 Node.js 免安装版(zip)安装与配置教程(2026 最新)
前端·windows·node.js
冬奇Lab5 小时前
每日一个开源项目(第105篇):Twenty - 跳出 Salesforce 的圈套,定义现代开源 CRM
前端·后端·开源
zhangyao9403305 小时前
开发pc端时,表格的高度怎么设置才能铺满页面
前端·javascript·elementui
kjs--6 小时前
浏览器书签执行脚本
前端
之歆6 小时前
Day16_JavaScript 轮播图与事件工程实战(下篇)
服务器·开发语言·前端·javascript·网络·性能优化
沄媪6 小时前
CSRF 跨站请求伪造
前端·ctf·csrf