深入学习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;}

登录后复制

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

1.png

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

立即学习“前端免费学习笔记(深入)”;

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

:is

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

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

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

举例1. 全局 :is

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

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

    
        

p1

    
    
        

p2

    
    
        

p3

    

登录后复制

初级版本(新手)

对于很多新手,确实是会出现下面的写法:针对不同的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;}

登录后复制

2.png

举例2 特定元素:is

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

        p1
    p2
    p3

p4

登录后复制

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

:is(.textColor) {    color:red;}.pColor{   color: black;}

p4

登录后复制

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

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

登录后复制

3.png

多个:is

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

h1

  

h2

  

h3

  

h4

登录后复制

4.png

权重

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

        
  1. li1
  2.     
  3. li2

登录后复制

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

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

登录后复制

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

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

5.png

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

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

登录后复制

6.png

:where

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

      
  1. li1
  2.   
  3. li2

登录后复制

这里我们:

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

登录后复制

最后的结果是蓝色

7.png

应用场景

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

8.png

PS: 可以优化前言中的小栗子

原文地址:https://juejin.cn/post/7005366966554722312

作者:前端picker

更多编程相关知识,请访问:编程视频!!

以上就是深入学习CSS中的 :is() 和 :where(),让样式代码更简洁!的详细内容,更多请关注【创想鸟】其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2871551.html

(0)
上一篇 2025年3月10日 18:36:09
下一篇 2025年3月5日 03:20:18

AD推荐 黄金广告位招租... 更多推荐

相关推荐

  • CSS怎么实现瀑布流?两种方式介绍

    css怎么实现瀑布流?下面本篇文章给大家介绍一下使用css实现瀑布流的两种方式,希望对大家有所帮助! 瀑布流又称瀑布流式布局,是比较流行的一种网站页面布局方式。在手机端进行多图片展示时会经常用到。即多行等宽元素排列,后面的元素依次添加到其后…

    2025年3月10日
    200
  • 手把手带你通过5个例子来熟悉CSS变量!

    大家对css变量熟悉吗?如果不熟悉,不要紧!下面本篇文章就来给大家介绍一下css变量,通过5个例子来带大家熟悉css变量,希望对大家有所帮助! 随着 Web应用程序变得越来越大,CSS变得越来越大,越来越冗长,而且混乱不堪。 在良好的上下文…

    2025年3月10日 编程技术
    200
  • 纯CSS做一个烟花绽放动画(代码示例)

    本篇文章带大家使用纯css做一个烟花绽放动画,希望对大家有所帮助! 最近项目上需要做一个烟花动画,要求是随机大小,不同地方出现,先看效果 一、选择合适的动画 什么样的场景决定使用什么样的动画。比如一些比较轻量、装饰性的动画,CSS 动画就足…

    2025年3月10日 编程技术
    200
  • css数字文本过长被隐藏了怎么办

    css数字文本过长被隐藏的解决方法:1、打开相应的HTML文件;2、使用“word-break”属性,给包含数字的元素添加“word-break:break-all;”样式,让数字文本自动换行即可全部显示出来即可。 本教程操作环境:wind…

    2025年3月10日 编程技术
    200
  • css怎么去掉表格重复的边框

    在css中,可以使用border-collapse属性来去掉表格中重复的边框,该属性可以设置表格边框是折叠为单一边框还是分开的,只需要将值设置为collapse即可把重叠的边框合并在一起,成为一个边框,实现单线边框的效果。 css/edit…

    2025年3月10日
    200
  • 巧用css filter的drop-shadow()函数创建线条光影效果

    本文将介绍一种利用 css 滤镜 filter 的 drop-shadow(),实现对 html 元素及 svg 元素的部分添加阴影效果,以实现一种酷炫的光影效果,用于各种不同的场景之中。 通过本文,你可以学到: 如何利用 filter: …

    2025年3月10日 编程技术
    200
  • css怎么修改字体颜色

    在css中,可以使用color属性来修改字体颜色,该属性的作用就是设置文本的颜色,只需要给包含字体文本的元素添加“color:颜色值;”即可。颜色值可以使用颜色名、十六进制数值、RGB或RGBA值、HSL或HSLA值来定义。 本教程操作环境…

    2025年3月10日
    200
  • css怎么设置超出显示省略号

    css设置超出显示省略号的方法:1、使用“overflow:hidden;”语句把超出的部分隐藏起来;2、使用“text-overflow:ellipsis;”语句在文本溢出包含元素时,显示省略符号来代表被隐藏的部分。 本教程操作环境:wi…

    2025年3月10日
    200
  • css怎么实现三角形

    实现方法:1、利用高宽为零的容器和透明的border;2、利用线性渐变linear-gradient;3、使用“transform:rotate”配合“overflow:hidden”;4、利用“▼”、“▲”等字符绘制。 本教程操作环境:w…

    2025年3月10日 编程技术
    200
  • css如何设置边框圆角

    在css中,可以利用border-radius属性来设置边框圆角,该属性的作用就是给边框添加圆角效果,只需要给元素添加“border-radius:圆角半径值;”样式,即可同时设置四个边框的圆角效果。 本教程操作环境:windows7系统、…

    2025年3月10日 编程技术
    200

发表回复

登录后才能评论