CSS3新特性值逻辑选择器

css3,特性,逻辑,选择器 · 浏览次数 : 49

小编点评

**1. :is** * 选择器列表作为参数。 * 选择任何一个选择器可以选择的元素。 * 例如:`header p:hover` 选择所有与 `header` 元素相关的元素的背景颜色变为红色,无论其层次。 **2. :where** * 与 :is 一样,选择器列表作为参数。 * 优先级为 0。 * 例如:`:where(div)` 选择所有所有 `div` 元素。 **3. :not** * 选择与指定选择器列表不匹配的元素。 * 通常用于防止特定的元素被选中。 **4. :has** *接受一个选择器组作为参数。 * 该选择器必须匹配至少一个元素。 **5. within** * 匹配一个元素的后代元素。 * 必须是该元素的祖先元素的最后一个子元素。 **6. focus-within** * 匹配一个元素的后代元素,该元素获得焦点。 * 必须是该元素的祖先元素的最后一个子元素。 **7. ::first-letter** * 选择第一个字母的块级元素或行内块元素。 **8. ::selection** * 选择元素的选中文本。

正文

1. :is

解释::is() CSS伪类函数将选择器列表作为参数,并选择该列表中任意一个选择器可以选择的元素。

例如

  • 对于多个不同父容器的同个子元素的一些共性样式设置,传统写法如下
  header p:hover,
  main p:hover,
  footer p:hover {
  color: red;
  cursor: pointer;
}

有了:is之后可以这么写

:is(header, main, footer) p:hover {
  color: red;
  cursor: pointer;
}

2. :where 伪类选择器

解释:与:is类似,:where 同样是将选择器列表作为其参数,并选择可以由该列表中的选择器之一选择的任何元素。与:is的区别就是 :where优先级总为0

例如

  • html代码如下
<div>
    <p>where & is test</p>
</div>
  • css代码如下
:is(div) p {
    color: red;
}
:where(div) p {
    color: green;
}

正常按我们的理解而言,:is(div) p 和 :where(div) p 都可以转化为 div p,由于 :where(div) p 后定义,所以文字的颜色,应该是 green 绿色,但是,实际的颜色表现为 color: red 红色:
这是因为,:where() 和 :is() 的不同之处在于,:where() 的优先级总是为 0 ,但是 :is() 的优先级是由它的选择器列表中优先级最高的选择器决定的。

3.:not 伪类选择器

解释::not 伪类选择器用来匹配不符合一组选择器的元素。由于它的作用是防止特定的元素被选中,它也被称为反选伪类(negation pseudo-class)。

例如:

  • html如下
<div class="a">div.a</div>
<div class="b">div.b</div>
<div class="c">div.c</div>
<div class="d">div.d</div>
div:not(.b) {
    color: red;
}

div:not(.b) 它可以选择除了 class 为 .b 元素之外的所有 div 元素:

tips:继承性属性可能会失效 注意!!!!

4.:has 伪类选择器

解释::has 伪类接受一个选择器组作为参数,该参数相对于该元素的 :scope 至少匹配一个元素。

例如

div>
    <p>div -- p</p>
</div>
<div>
    <p class="g-test-has">div -- p.has</p>
</div>
<div>
    <p>div -- p</p>
</div>

div:has(.g-test-has) {
    border: 1px solid #000;
} 

我们通过 div:has(.g-test-has) 选择器,意思是,选择 div 下存在 class 为 .g-test-has 的 div 元素。

  • :has() 父选择器 -- 嵌套结构的父元素选择
<div>
    <span>div span</span>
</div>

<div>
    <ul>
        <li>
            <h2><span>div ul li h2 span</span></h2>
        </li>
    </ul>
</div>

<div>
    <h2><span>div h2 span</span></h2>
</div>

div:has(>h2>span) {
    margin-left: 24px;
    border: 1px solid #000;
}

这里,要求准确选择 div 下直接子元素是 h2,且 h2 下直接子元素有 span 的 div 元素。注意,选择的最上层使用 :has() 的父元素 div。

  • :has() 父选择器 -- 同级结构的兄元素选择
<div class="has-test">div + p</div>
<p>p</p>

<div class="has-test">div + h1</div>
<h1>h1</h1>

<div class="has-test">div + h2</div>
<h2>h2</h2>

<div class="has-test">div + ul</div>
<ul>ul</ul>

我们想找到兄弟层级关系中,后面接了h2元素的 .has-test 元素,可以这样写:

.has-test:has(+ h2) {
    margin-left: 24px;
    border: 1px solid #000;
}

tips::has() 兼容性不太好

5. within

解释::within 伪类选择器用来匹配一个元素的后代元素,该元素必须是该元素的祖先元素的最后一个子元素。

例如

<div class="within-test">
    <p>within-test</p>
    <p>within-test</p>
    <p>within-test</p>
</div>
.within-test:within {
    border: 1px solid #000;
}

这里,我们通过 .within-test:within 选择器,意思是,选择 .within-test 元素的最后一个子元素,即最后一个 p 元素。

6. focus-within

解释::focus-within 伪类选择器用来匹配一个元素的后代元素,该元素必须是该元素的祖先元素的最后一个子元素,并且该元素或者该元素的后代元素获得了焦点。

例如

<div class="focus-within-test">
    <p>focus-within-test</p>
    <p>focus-within-test</p>
    <p>focus-within-test</p>
</div>
.focus-within-test:focus-within {
    border: 1px solid #000;
}

7. ::fist-letter

解释:::first-letter 伪元素选择器用来匹配一个元素的第一个字母,该元素必须是块级元素或者行内块元素。

例如

<p class="first-letter-test">first-letter-test</p>
.first-letter-test::first-letter {
    font-size: 24px;
    color: red;
}

8. ::selection

解释:::selection 伪元素选择器用来匹配一个元素的选中文本,该元素必须是块级元素或者行内块元素。

例如

<p class="selection-test">selection-test</p>
.selection-test::selection {
    background-color: red;
    color: #fff;
}

更多例子可以参考:https://zhuanlan.zhihu.com/p/516155516

与CSS3新特性值逻辑选择器相似的内容:

CSS3新特性值逻辑选择器

1. :is 解释::is() CSS伪类函数将选择器列表作为参数,并选择该列表中任意一个选择器可以选择的元素。 例如 对于多个不同父容器的同个子元素的一些共性样式设置,传统写法如下 header p:hover, main p:hover, footer p:hover { color: red;

CSS3 超实用属性:pointer-events (可穿透图层的鼠标事件)

1、是什么 pointer-events 直译为指针事件,该属性指定在什么情况下某个DOM可以成为鼠标事件的 target。 简而言之,就是允许/禁止DOM的鼠标事件(click事件、hover事件、mouse事件等鼠标事件) 2、具体属性分析 用法分析:pointer-events: auto |

暗夜发光,独自闪耀,盘点网页暗黑模式(DarkMode)下的特效和动效,CSS3实现

众所周知,网页的暗黑模式可以减少屏幕反射和蓝光辐射,减少眼睛的疲劳感,特别是在夜间使用时更为明显。其实暗黑模式也给霓虹灯效应(Neon Effect)提供了发挥的环境。 霓虹灯效应是一种视觉效果,其特点是在深色背景上使用鲜艳的颜色来产生强烈的视觉冲击。这种效应通常用于设计海报、广告、标志和网页等。霓

如何优雅的实现动画效果

1.实现动画的方式 javaScript:setTimeout、setInterval css3: transition、animation html: canvas requestAnimationFrame Api 前三种我们都很熟悉,重点说说requestAnimationFrame 2.re

颜值即正义,献礼就业季,打造多颜色多字体双飞翼布局技术简历模版(Resume)

一年好景君须记,最是橙黄橘绿时。金三银四,秣马厉兵,没有一个好看的简历模板怎么行?无论是网上随便下载还是花钱买,都是一律千篇的老式模版,平平无奇,味同嚼蜡,没错,蜡都要沿着嘴角流下来了。本次我们基于Html和Css3打造一款独立实现的高颜值简历模板,就像看岛国的爱情片儿一样,也许你会找自己喜欢的主题

博客园主题修改分享 - 过年篇

马上就要过年了,看着我这毫无生气的博客,感觉有点亏待它。博客过年,马上安排! 本篇部分知识基于上两篇博客博客园主题修改分享和博客园主题修改分享 - 脚本篇。 先上效果图 1. 设置全局css变量 主要是通过css3的变量设置,统一博客界面的颜色。 :root { --bg: #f5f7f9; /*

IoTBrowser V2.0:引领物联网时代的全新浏览器

强大的兼容性,无限的可能 IoTBrowser V2.0,基于Chromium内核,完美支持H5/css/js开发界面,让您的物联网应用拥有与主流浏览器同等的流畅体验。同时,它还支持CSS 3动画、Cesium.js、Three.js等先进技术,让您的界面更加绚丽、动态。无论是ES6的Prom

Vue - 入门

零:前端目前形势 前端的发展史 HTML(5)、CSS(3)、JavaScript(ES5、ES6):编写一个个的页面 -> 给后端(PHP、Python、Go、Java) -> 后端嵌入模板语法 -> 后端渲染完数据 -> 返回数据给前端 -> 在浏览器中查看 Ajax的出现 -> 后台发送异步请