返回顶部
首页 > 资讯 > 前端开发 > JavaScript >CSS中的 :is() 和 :where()怎么用
  • 561
分享到

CSS中的 :is() 和 :where()怎么用

2024-04-02 19:04:59 561人浏览 八月长安
摘要

这篇文章将为大家详细讲解有关CSS中的 :is() 和 :where()怎么用,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。新人在入门CSS的时候

这篇文章将为大家详细讲解有关CSS中的 :is() 和 :where()怎么用,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。

新人在入门CSS的时候,往往最困惑的就是两件事情(个人想法):1. CSS是基于文档流的,有些时候编写的代码,并不符合自己的预期! 2.复杂的选择器,什么场景用什么选择器,选择器太长,让新人很困恼,。最近在公司的代码中发现了这样一段代码。

.home .col .card a i.i1,
.home .col .card a i.i2,
.home .col .card a i.i3,
.home .col .card a i.i4,
.home .col .card a i.i5,
.home .col .card a i.i5,
.home .col .card a i.i6,
.home .col .card a i.i7 {
  background-size: 35px;
  width: 60px;
  height: 42px;
  margin: auto;
}

乍一看真的特别多,作为交接人,我真的看呆了,这也忒长了吧。

CSS中的 :is() 和 :where()怎么用

大家可以开动自己的小脑筋,尝试不同的方案,去简化简写这段带代码!

本文我们来讲讲css3比较高效的选择器,保证让人眼前一亮的选择器。

:is

用更少的代码去更有效地选择元素!666,牛逼!!!

简单的来说就是 通过提取共通的选择器,来简化代码!

注意: :is() 原名  :match()

举例1. 全局 :is

场景:在前端开发的时候,某些情况下,在不同的div下,可能文本的颜色是一致的。

例如下面的三个div,三个div的文本颜色都是红色。

    <div class="div1">
        <p>p1</p>
    </div>
    <div class="div2">
        <p>p2</p>

    </div>
    <div class="div3">
        <p>p3</p>
    </div>

初级版本(新手)

对于很多新手,确实是会出现下面的写法:针对不同的div的p进行相同的设置。

.div1>p{
    color:red;
}
.div2>p{
    color:red;
}
.div3>P{
    color:red;
}

进阶版本

随着编写代码的增多,新手逐渐发现,有很多共同的代码,可以提取出来。比如这里的color:red ,就可以提取出来。哇,代码瞬间减少了很多!!!

.div1>p,
.div2>p,
.div3>P{
    color:red;
}

高级版本(:is)

这时候新手又觉得了,既然color:red;可以提出来,那为什么p不提出来呢? 于是出现了下面更简洁的版本。

:is(.div1,.div2,.div3) >P {
  color:red;
}

CSS中的 :is() 和 :where()怎么用

举例2 特定元素:is

且看下面的代码,我们想要实现div的颜色是红色的,并且颜色定义是在textColor种,并且保持p是黑色的。

<div class="textColor">
        p1
</div>
<div class="textColor">
    p2
</div>
<div class="textColor">
    p3
</div>
<p class="textColor">p4</p>

看了上面的举例1,我估计有些新手就要开始这样写了:直接给p标签添加新的式样。

:is(.textColor) {    color:red;

}.pColor{   color: black;
}
<p class="textColor pColor">p4</p>

但是:is是支持特定元素的写法的:你只需要在:is 前面添加

div:is(.textColor) {
    color:red;
}

CSS中的 :is() 和 :where()怎么用

多个:is

div:is(.textColor) :is(h2,h5){
  color:red;
}
<div class="textColor">
  <h2>h2</h2>
  <h3>h3</h3>
  <h4>h4</h4>
  <h5>h5</h5>
</div>

CSS中的 :is() 和 :where()怎么用

权重

:is 的权重是由提供的id,元素等选择器决定的;可能比较难理解。一个例子马上明白。

<ol id="olID">
    <li>li1</li>
    <li>li2</li>
</ol>

我们来更改li的字体颜色。

:is(ol) li {
  color: red;
}
ol li {
  color: blue;
}

大家可以猜一下是什么颜色。

是蓝色:为啥呢,首先is的参数是ol与下面的那个ol选择器的权重一致。并且由于blue是在下面的,浏览器自动使用blue覆盖掉了red。

CSS中的 :is() 和 :where()怎么用

再看下面的写法,我们给is的参数加了一个id: #olID,最终的颜色就是红色。这就是因为is使用了权重更高的id选择器。

 :is(ol,#olID) li {
        color: red;
      }
      ol li {
        color: blue;
      }

CSS中的 :is() 和 :where()怎么用

:where

:where和:is的语法参数完全一致。唯一不同的就是:where的权重永远为0,或者说是最卑微的。 还是上面那个例子。

<ol id="olID">
  <li>li1</li>
  <li>li2</li>
</ol>

这里我们:

:where(ol,#olID) li {
  color: red;
}
ol li {
  color: blue;
}

最后的结果是蓝色

CSS中的 :is() 和 :where()怎么用

应用场景

因为要说了,既然有了is为啥还要:where?个人觉得,:where还是很有用的。比如说在开发组件库的时候,可以使用,因为where的权重很低,那么使用者是不是很容易覆盖了,就不需要什么!imprtant,v-deep之类的了。

CSS中的 :is() 和 :where()怎么用

关于CSS中的 :is() 和 :where()怎么用就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。

--结束END--

本文标题: CSS中的 :is() 和 :where()怎么用

本文链接: https://lsjlt.com/news/81914.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • CSS中的 :is() 和 :where()怎么用
    这篇文章将为大家详细讲解有关CSS中的 :is() 和 :where()怎么用,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。新人在入门CSS的时候...
    99+
    2024-04-02
  • CSS :is() 和 :where()有什么用
    这篇文章主要介绍了CSS :is() 和 :where()有什么用,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。现在,Safari(技术预览版106)和Firefo...
    99+
    2023-06-08
  • CSS的:Where和:Is伪类函数怎么用
    今天小编给大家分享一下CSS的:Where和:Is伪类函数怎么用的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。什么...
    99+
    2023-07-04
  • CSS中的 :Where 和 :Is 伪类函数是什么
    本篇内容主要讲解“CSS中的 :Where 和 :Is 伪类函数是什么”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“CSS中的 :Where...
    99+
    2024-04-02
  • linux中find和whereis命令怎么用
    这篇文章主要为大家展示了“linux中find和whereis命令怎么用”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“linux中find和whereis命令怎么用”这篇文章...
    99+
    2023-06-17
  • CSS中:where和:is伪类函数的介绍
    这篇文章主要讲解了“CSS中:where和:is伪类函数的介绍”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“CSS中:where和:is...
    99+
    2024-04-02
  • Linux中whereis命令怎么用
    这篇文章主要介绍了Linux中whereis命令怎么用,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。Linux whereis 命令wherei...
    99+
    2023-06-16
  • Linux whereis命令怎么用
    这篇文章主要介绍了Linux whereis命令怎么用的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇Linux whereis命令怎么用文章都会有所收获,下面我们一起来看看吧。在 Linux...
    99+
    2023-06-28
  • Linux系统中whereis命令怎么用
    小编给大家分享一下Linux系统中whereis命令怎么用,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!Linux whereis命令用于查找...
    99+
    2023-06-28
  • linux中whereis命令有什么用
    小编给大家分享一下linux中whereis命令有什么用,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!whereis命令只能用于程序名的搜索,...
    99+
    2023-06-09
  • Linux下whereis命令怎么使用
    这篇文章主要讲解了“Linux下whereis命令怎么使用”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Linux下whereis命令怎么使用”吧!Linux下搜寻文件,...
    99+
    2023-06-27
  • pandas中Where怎么用
    这篇文章主要介绍了pandas中Where怎么用,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。WhereWhere用来根据条件替换行或列中的值。...
    99+
    2023-06-03
  • laravel中where怎么用
    laravel中where的用法:1、使用and/or条件连接符,使用"orWhere"方法来添加一个或条件,可以检索大于某项数据的用户数据;2、使用between条件操作符,使用"wher...
    99+
    2023-08-04
  • Linux中whereis命令如何使用
    这篇文章将为大家详细讲解有关Linux中whereis命令如何使用,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。Linux常用命令whereis命令 用来定位指令的二进制程序、源代码文...
    99+
    2023-06-28
  • SQL中having和where怎么使用
    在SQL中,HAVING子句和WHERE子句都用于筛选数据,但它们的使用场景有所不同。 WHERE子句: ...
    99+
    2024-04-19
    SQL
  • oracle中where in怎么用
    where in 子句在 oracle 中用于检查列值是否อยู่ใน特定值列表中:语法:where column_name in (value1, value2, ...
    99+
    2024-04-30
    oracle
  • Linux whereis命令的使用方法
    这篇文章的内容主要围绕Linux常用命令whereis命令的使用方法进行讲述,文章内容清晰易懂,条理清晰,非常适合新手学习,值得大家去阅读。感兴趣的朋友可以跟随小编一起阅读吧。希望大家通过这篇文章有所收获!Linux常用命令whe...
    99+
    2023-06-28
  • Linux基础命令whereis的用法
    本篇内容介绍了“Linux基础命令whereis的用法”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!whereis查找命...
    99+
    2023-06-06
  • MySQL where条件is null 及is not null 的用法
    首先先了解is null 与 is not null 分别代表什么;is null 在查询中用于查询指定字段为null的数据、is not null 在查询中用于查询指定字段中不为null的数据(手动删除的无法查询); 语法为 selec...
    99+
    2023-09-25
    mysql Powered by 金山文档
  • Oracle中where子句怎么用
    这篇文章给大家分享的是有关Oracle中where子句怎么用的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。查询emp表中20号部门的员工信息select&nb...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作