深入了解 CSS 中的 :where() 和 :is() 函数

这篇具有很好参考价值的文章主要介绍了深入了解 CSS 中的 :where() 和 :is() 函数。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

深入了解 CSS 中的 :where() 和 :is() 函数

:where() 函数接受一个选择器列表作为参数,允许你编写更少的代码并同时设置它们的样式。在本文中,我们将讨论 :where() 伪类函数,并演示如何在生产环境中使用它。我们将回顾与 :where() 函数相关的叠加、优先级和安全性。我们还将研究一些特定的用例,并讨论它与 :is() 函数的异同。

1.什么是 :where() 函数?

根据 MDN,:where() 是一个 CSS 伪类函数选择器,它接受一个选择器列表作为参数,并将给定的样式应用于该列表中的任何元素,因此:where() 对于缩短一个较长的选择器列表非常有用。

在 CSS 中,当多个元素同时应用相同的样式规则时,我们通常会编写一长串以逗号分隔的选择器。

下面是一个例子,我们将相同的样式应用到 headermain 元素和 footer 元素中的所有 <a> 标签:

header a:hover,
main a:hover,
footer a:hover {
  color: green;
  text-decoration: underline;
}

在上面的代码片段中,我们只选择了三个元素,但是如果有大量的元素和选择器,代码将开始看起来不整洁,并且可能变得难以阅读和理解。这就是 :where() 伪类函数发挥作用的地方。

下面是上面的例子使用 :where() 函数的样子:

:where(header, main, footer) a:hover {
  color: red;
  text-decoration: underline;
}

当浏览器到达该代码片段时,该代码指示浏览器查找 headermainfooter 选择器,并定位这些选择器中的所有 a 标签。然后,当用户将鼠标悬停在任何这些 a 标签上时,浏览器应该应用指定的样式,在本例中为红色和下划线。这个伪类函数使我们能够以更短、更容易理解的方式编写一个很长的选择器列表。

2. 组合、分割和叠加 :where() 函数

使用 :where() 函数,我们可以以多种方式和组合对元素进行分组。我们可以将 :where() 函数放在选择器的开头、中间或结尾。下面是一个有多个选择器和样式的例子:

/* first list */
header a:hover,
main a:hover,
footer a:hover {
  color: green;
  text-decoration: underline;
}

/* second list */
article header > p,
article footer > p{
	color: gray;
}

/* third list */
.dark-theme button,
.dark-theme a,
.dim-theme button,
.dim-theme a{
	color: purple;
}

下面是相同的代码,用 :where() 函数重写:

/* first list */
/* at the beginning */
:where(header, main, footer) a:hover {
  color: red;
  text-decoration: underline;
}

/* second list */
/* in the middle */
article :where(header, footer) > p {
	color: gray;
}

/* third list */
/* at the end */
.dark-theme :where(button, a) {
	color: purple;
}
.dim-theme :where(button, a) {
	color: purple;
}

在第一个列表中,我们指定红色下划线样式应应用于悬停时的 headermain 元素和 footer 元素。在第二个列表中,我们指定 articleheaderfooter 元素应该使用灰色样式。

为了更清晰,我们将第三个列表分为两个 :where() 函数。在这个列表中,我们指定 .dark-theme、.dim-theme 里的 buttona 元素的样式应该是紫色

现在,我们将进一步减少第三个列表函数,将它们变成一个 :where() 函数:

/* stacked */
:where(.dark-theme, .dim-theme) :where(button, a) {
  color: purple;
}

这种减少复杂选择器列表的策略称为叠加。

3. :where() 选择器的优先级

:where() 函数选择器的优先级总是零。因此,以该函数为目标的任何元素也会自动获得 0 的优先级。这使我们能够轻松地取消任何元素的样式。

下面是一个 HTML 有序列表的例子:

<div>
  <h2>First list no class</h2>
  <ol>
    <li>List Item 1</li>
    <li>List Item 2</li>
  </ol>
</div>
<div>
  <h2>Second list with class</h2>
  <ol class="second-list">
    <li>List Item 1</li>
    <li>List Item 2</li>
  </ol>
</div>

<div>
  <h2>Third list with class</h2>
  <ol class="third-list">
    <li>List Item 1</li>
    <li>List Item 2</li>
  </ol>
</div>

在上面的代码片段中,有三个有序列表,每个列表中有两个项。第二个和第三个列表有一个给定的类,而第一个列表没有。

没有任何样式,我们可以看到每个列表是按数字顺序排列的:

image.png

现在,让我们添加一些样式:

:where(ol[class]) {
	list-style-type: none;
}

在上面的代码片段中,我们使用 :where() 伪类函数来选择应用了类的所有 ol 标签。

下面,我们看到第二个和第三个列表,它们都有一个类,被 :where() 函数作为目标,并删除了它们的 list-style-type

image.png

现在,让我们添加一些额外的样式:

:where(ol[class]) {
  list-style-type: none;
}

.second-list {
  list-style-type: disc;
}

只针对使用类名的第二个列表,我们可以看到它现在显示为项目符号,而第三个列表仍然没有列表样式类型:

image.png

你可能会想,“这不应该是这样吗,因为新的样式写在 :where() 函数样式下面?”不,它不是,我们一会儿就会看到。

让我们看看当我们把刚刚添加的代码移到代码块的顶部,并把 :where() 函数部分移到底部时,会发生什么:

.second-list {
  list-style-type: disc;
}

:where(ol[class]) {
  list-style-type: none;
}

注意样式仍然没有改变:

image.png

记住,:where() 函数的优先级为零。

4. :where() 选择器的安全性

对于选择器列表,如果浏览器不能识别列表中的一个选择器,则整个选择器列表将被视为无效,并且它们的样式将不会被应用。然而,对于 :where() 伪类函数就不是这样了。

如果 :where() 函数中的元素是无效选择器的目标,则该元素将不会获得任何样式。其余的元素仍然会被设置样式。:where() 函数将跳过无效的选择器到下一个(有效)选择器。这就是为什么 :where() 被称为安全的选择器。

在下面的例子中,:unsupported 对于许多浏览器来说是无效的选择器。下面的代码将被正确解析,并且仍然会匹配 :valid 选择器,即使在不支持 :unsupported 选择器的浏览器中,如下所示:

:where(:valid, :unsupported) {
  ...
}

然而,在不支持 :unsupported 选择器的浏览器中,以下代码将被忽略,即使它们支持 :valid 选择器:

:valid, :unsupported {
  ...
}

5. :where() 函数的特殊用例

在一些特殊的用例中,:where() 函数可能是一个有用的工具,但也有一些情况下应该避免使用它。使用 :where() 伪类函数时出现的几乎所有问题都归结为优先级。因为 :where() 的优先级为零,我们需要非常小心地选择何时何地使用这个函数。

首先,让我们看看几个用例,在这些用例中 :where() 可能特别有用。

5.1 改进 CSS 重置

CSS 重置是指在任何其他样式之前加载一组样式规则,以清除浏览器的内置样式。CSS 重置通常放置在 CSS 样式表的顶部或开始,所以它们首先加载。开发人员通常使用它们来删除浏览器最初给几个元素的默认样式,然后才开始实际设计他们的元素和网站。CSS 重置还可以帮助消除不同浏览器之间的不一致。

CSS 重置是临时的样式,稍后会在样式化过程中更改。然而,根据 CSS 重置中使用的元素或元素组的选择器的简单性或复杂性,稍后在代码中可能很难覆盖初始样式。

例如,假设我们将网站上的所有的 a 标签设置为绿色。然后,我们稍后决定将所有 header 里的 a 标签的样式设置为灰色

由于在 CSS 重置中选择的复杂性,新的(灰色)样式不会被应用。重置中的选择器比后面代码中仅针对 header 里的 a 标签使用的选择器具有更高阶的优先级,因此没有应用灰色样式。

现在,如果我们将 :where() 伪类函数添加到 CSS 重置中,这将自动为重置中的所有元素赋予零的优先级。这使得我们以后更容易更改样式,而不必担心优先级冲突。

5.2 删除样式

如果想要删除或取消样式或降低一个或一组元素的优先级,则 :where() 函数非常有用。

5.3 保持样式

如果要确保一个元素或元素集的样式或优先级在未来的任何时候都不会改变,那么不要使用 :where() 伪类。

6. 什么是 :is() 函数?

:is() 函数的运行方式几乎与 :where() 函数相同。你可以用它来简化复杂的选择器,也可以把它放在选择器的开头、中间或结尾,就像 :where() 函数一样。

它也是安全的,就像 :where() 函数一样。因此,当其中一个选择器无效时,浏览器将忽略该选择器,但有效选择器的样式将添加到所选元素中。

7. :where() 和 :is() 函数的区别

这两个函数的区别在于 :where() 函数的优先级总是零,则 :is() 函数的优先级取决于其最特定参数的优先级。例如,让我们看看 header 元素中的段落文本:

<header>
  <p>This is a paragraph text.</p>
</header>

然后,让我们尝试使用四种不同的选择器来改变文本颜色:

header p {
  color: blue;
}

:is(header, section) p {
  color: green;
}

p {
  color: blue;
}

:where(header, section) p {
  color: blue;
}

第一个选择器将文本的颜色设置为蓝色。使用 :is() 的第二个选择器与第一个选择器具有相同的优先级,但由于它位于第一个选择器之后,因此它将文本颜色从蓝色更改为绿色。第三个选择器的优先级低于第一个和第二个选择器,对文本没有影响。最后是第四个,它使用 :where() 函数对文本没有影响,因为它的零优先级。

8. 浏览器兼容性

所有浏览器,无论是桌面浏览器还是移动浏览器,都完全支持 CSS :where() 函数,包括对其安全特性的支持。因此,你 不必担心你 的样式是否会在浏览器中正确呈现。文章来源地址https://www.toymoban.com/news/detail-403628.html

到了这里,关于深入了解 CSS 中的 :where() 和 :is() 函数的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 深入了解MySQL中的JSON_ARRAYAGG和JSON_OBJECT函数

    在MySQL数据库中,JSON格式的数据处理已经变得越来越常见。JSON(JavaScript Object Notation)是一种轻量级的数据交换格式,它可以用来存储和表示结构化的数据。MySQL提供了一些功能强大的JSON函数,其中两个关键的函数是JSON_ARRAYAGG和JSON_OBJECT。本文将深入探讨这两个函数的用途、

    2024年02月09日
    浏览(38)
  • 【Java 进阶篇】深入了解 Bootstrap 全局 CSS 样式

    Bootstrap 是一个流行的前端框架,以其强大的全局 CSS 样式而闻名。这些样式能够帮助开发者快速创建漂亮的、响应式的网页,而无需从头编写复杂的 CSS。在本文中,我们将深入探讨 Bootstrap 的全局 CSS 样式,适合初学者,帮助他们更好地理解和应用这些样式。 全局 CSS 样式是

    2024年02月07日
    浏览(40)
  • 深入了解Js中的对象

    在JavaScript中,对象是个无序的键值对数据集。例如: 上述例子中的小强是一位年轻人,对于这个对象我们用一个括号进行定义。在括号体内我们描述了这个人的几种属性:姓名、年龄、所在城市,工作等。 每一个属性对应一个值,形成了一个数据集。 我们可以通过点操作符

    2024年02月05日
    浏览(44)
  • 了解CSS中的BFC以及用法

    目录 一 常见的定位方案 1. 普通流(所有元素默认为普通流的定位) 2. 浮动 3. 绝对定位 二  BFC  1. 定义 2. 触发条件 3. 作用 (1) 避免外边距重叠 ​(2)清除浮动 (3) 阻止元素被浮动元素覆盖         首先,先了解一下常见的定位方案。有三种:普通流(默认)、浮

    2024年04月12日
    浏览(33)
  • 【c++】类和对象(四)深入了解拷贝构造函数

    🔥 个人主页 :Quitecoder 🔥 专栏 :c++笔记仓 朋友们大家好啊,本篇内容带大家深入了解 拷贝构造函数 拷贝构造函数是一种特殊的构造函数,在对象需要以同一类的另一个对象为模板进行初始化时被调用。它的主要用途是初始化一个对象,使其成为另一个对象的副本 我们先

    2024年04月16日
    浏览(68)
  • 深入了解Golang中的反射机制

    目录 反射 反射的分类 值反射 类型反射 运行时反射 编译时反射 接口反射 结构体反射 常用函数 值反射 类型反射 值反射和类型反射的区别 结构体反射 示例代码         反射是指在程序运行时动态地检查和修改对象的能力。在Go语言中,通过反射可以在运行时检查变量的

    2024年02月06日
    浏览(49)
  • MySQL | 深入了解如何最大化利用 MySQL 函数(一)

    前言 ✨欢迎来到小K的MySQL专栏,本节将为大家带来MySQL字符串函数和数学函数的讲解 ✨ 一、字符串函数 函数 作用 UPPER(列|字符串) 将字符串每个字符转为大写 LOWER(列|字符串) 将字符串每个字符转为小写 CONCAT(str1,str2,…) 将所有字符串连接成一个字符串 REPLACE(列|字符串,新字符

    2024年02月08日
    浏览(50)
  • 深入了解 Elasticsearch 8.1 中的 Script 使用

    Elasticsearch 中的 Script 是一种灵活的方式,允许用户在查询、聚合和更新文档时执行自定义的脚本。这些脚本可以用来动态计算字段值、修改查询行为、执行复杂的条件逻辑等等。 支持多种脚本语言,包括 Painless 、 Expression 、 Mustache 、 Java 等,其中默认的是 Painless 。 Painle

    2024年02月07日
    浏览(43)
  • Flutter 中的 ButtonStyle 和 MaterialStateProperty:深入了解

    Flutter 中的 ButtonStyle 和 MaterialStateProperty 是在 Flutter 2.0 发布时引入的。在 Flutter 1 中,我们可以通过设置 textColor、backgroundColor 等参数来快速配置按钮的样式。但是在 Flutter 2 中,这些参数被废弃了,取而代之的是 ButtonStyle。ButtonStyle 可以通过 MaterialStateProperty 来支持不同平台

    2024年02月02日
    浏览(34)
  • 深入了解Python的eval函数:基础用法与潜在危险【第118篇—eval函数】

    在Python中, eval 函数是一个强大而灵活的工具,它允许将字符串作为代码来执行。然而,虽然 eval 在某些情况下非常方便,但它也潜藏着一些潜在的危险,如果不小心使用,可能导致安全性问题。在本文中,我们将深入探讨 eval 函数的基础用法,并提供一些使用该函数时需要

    2024年03月12日
    浏览(46)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包