阅读视图

发现新文章,点击刷新页面。
🔲 ☆

今日学习CSS style()样式查询及其range范围语法

by zhangxinxu from https://www.zhangxinxu.com/wordpress/?p=11975
本文可全文转载,但需要保留原作者、出处以及文中链接,AI抓取保留原文地址,任何网站均可摘要聚合,商用请联系授权。

一、先了解下样式查询

@container规则除了尺寸匹配(这个支持有一段时间了),还支持样式匹配。

目前除了Chrome浏览器,Safari浏览器也已经支持了,实在是好消息啊!

容器样式匹配查询兼容性

我们先看一个基础的案例,基于--status变量显示不同的样式。

HTML代码如下:

<section class="card" style="--status: success;">
  <div class="status">成功</div>
</section>
<section class="card" style="--status: error;">
  <div class="status">失败</div>
</section>
<section class="card" style="--status: warning;">
  <div class="status">警告</div>
</section>

此时,我们就可以根据容器元素上的--status变量值进行针对性的样式设置,例如:

@container style(--status: success) {
  .status {
    background-color: green;
  }
}
@container style(--status: error) {
  .status {
    background-color: darkred;
  }
}
@container style(--status: warning) {
  .status {
    background-color: orange;
  }
}

此时,就可以得到类似下图的渲染效果:

容器变量背景色

想要查看完整CSS代码,您可以狠狠地点击这里:CSS容器样式查询基本使用demo

指定容器名称

如果有多个容器,用了同样的变量名称,那么上面的案例可能就有冲突的问题。

此时,我们可以通过给容器命名的方式进行处理。

请看案例。

<section class="card" style="--status: success;">
  <div class="status">卡片成功</div>
</section>
<section class="toast" style="--status: success;">
  <div class="status">提示成功</div>
</section>

以上两个<section>元素设置的变量是一样的,子元素也是一样的,此时想要有所区别,就需要使用container-name属性,CSS代码参考:

.card {
  container-name: card;   
}
.toast {
  container-name: toast;    
}
@container card style(--status: success) {
  .status {
    background-color: green;
  }
}
@container toast style(--status: success) {
  .status {
    background-color: #000;
    &::after {
      content: '√';
      margin-left: .5ch;
    }
  }
}

此时,就有如下截图所示的渲染效果:

不同名称的容器查询

同样的,也演示页面,您可以狠狠地点击这里:CSS容器名称精确匹配样式查询demo

二、再看下范围解析语法

单纯的CSS变量匹配并不能让开发人员兴奋,因为,通过属性选择器,某种意义上也是可以对CSS变量进行匹配的,例如:

.toast[style*="--status: success"] {
  /* 子元素巴拉巴拉…… */
}

但是,下面这个范围解析语法,一定会让你双眼放光。

举个简单的例子,不同的分数显示不同的颜色。

90分以上是金色,金色传说。
80分以上是绿色,60~80橙色,60分以下是红色。

则无需JS判断,CSS就能处理。

HTML如下所示:

<span class="score" style="--score: 95;">
  <data>95</data>
</span>
<span class="score" style="--score: 85;">
  <data>85</data>
</span>
<span class="score" style="--score: 65;">
  <data>65</data>
</span>
<span class="score" style="--score: 35;">
  <data>35</data>
</span>

此时,就可以在style()函数中,使用大于号,小于号进行匹配,代码来咯:

@container style(--score >= 90) {
  data {
    color: gold;
  }
}
@container style(--score >= 80) and style(--score < 90) {
  data {
    color: green;
  }
}
@container style(--score >= 60) and style(--score < 80) {
  data {
    color: orange;
  }
}
@container style(--score < 60) {
  data {
    color: red;
  }
}

通俗易懂,三岁小孩也能知道是什么意思。

效果图参考:

数字,金色传说

同样的,这个例子也有演示页面,您可以狠狠地点击这里:CSS样式查询range范围匹配分数颜色demo

四、其实使用普通属性也是可以的

Chrome浏览器已经支持全属性attr()函数语法了,所以,样式匹配的时候,普通属性也是可以支持的。

例如:

<span class="score" data-score="95">
  <data>95</data>
</section>
<span class="score" data-score="85">
  <data>85</data>
</section>
<span class="score" data-score="65">
  <data>65</data>
</section>
<span class="score" data-score="35">
  <data>35</data>
</section>
.score {
  --score: attr(data-score type(<number>));
}
@container style(--score >= 90) {
  data {
    color: gold;
  }
}
/* 这部分代码都是一样的,略 */

最终的效果效果是一样的:

数字,金色传说

五、我想匹配容器自身

只要是@container容器匹配,无论是尺寸查询、样式查询、滚动查询还是锚点查询,都是只能对后代元素进行设置,容器本身是无法直接匹配。

但是,对于样式查询而言,是有曲线救国的方案的,那就是使用 if() 函数。

所以,上面的分数高亮案例,HTML代码可以进一步简化:

<data class="score" value="95"></data>
<data class="score" value="85"></data>
<data class="score" value="65"></data>
<data class="score" value="35"></data>

更语义,更原生,更简洁。

CSS代码同样简单了很多:

.score {
  --score: attr(value type(<number>));
  &::before {
    content: attr(value);
  }
  color: if(
    style(--score >= 90): gold;
    style(--score >= 80): green;
    style(--score >= 60): orange;
    else: red;
  );
}

还是相当nice的!

if函数实现的数字颜色

如果您正在使用的是Chrome浏览器,那么您可以狠狠地点击这里:CSS样式查询if()函数匹配容器自身

六、样式查询也支持尺寸设置

style()函数里面也可以设置min-width,或者height等尺寸设置。

例如:

@container style(min-width: 200px) { … }

由于@container本身就支持尺寸查询,故而这个不可替代性一般,其典型应用还是CSS变量匹配。

哦呵呵~

七、2025年就这样结束啦

2025年就这样结束啦,这一年前端依然在不断进步,如果大家注意看我的更新的新特性,7~8成都是CSS新特性,倒不是我刻意筛选,真特么就是CSS特性比DOM和JS特性多。

2024年年底的时候,绝对想不到CSS会有上面这样的写法。

要是这一年不跟着学习。

CSS就会变成你不认识的样子。

相比之下,JavaScript还是当年的样子,满屏的Promise,async和await和箭头函数,其他大同小异。

CSS则是从书写到特性都大变样了。

展望2026,新的一年,还是要持续学习的啦,加油!

加油!

本文为原创文章,会经常更新知识点以及修正一些错误,因此转载请保留原出处,方便溯源,避免陈旧错误知识的误导,同时有更好的阅读体验。
本文地址:https://www.zhangxinxu.com/wordpress/?p=11975

(本篇完)

🔲 ☆

今日学习CSS style()样式查询及其range范围语法

by zhangxinxu from https://www.zhangxinxu.com/wordpress/?p=11975
本文可全文转载,但需要保留原作者、出处以及文中链接,AI抓取保留原文地址,任何网站均可摘要聚合,商用请联系授权。

一、先了解下样式查询

@container规则除了尺寸匹配(这个支持有一段时间了),还支持样式匹配。

目前除了Chrome浏览器,Safari浏览器也已经支持了,实在是好消息啊!

容器样式匹配查询兼容性

我们先看一个基础的案例,基于--status变量显示不同的样式。

HTML代码如下:

<section class="card" style="--status: success;">
  <div class="status">成功</div>
</section>
<section class="card" style="--status: error;">
  <div class="status">失败</div>
</section>
<section class="card" style="--status: warning;">
  <div class="status">警告</div>
</section>

此时,我们就可以根据容器元素上的--status变量值进行针对性的样式设置,例如:

@container style(--status: success) {
  .status {
    background-color: green;
  }
}
@container style(--status: error) {
  .status {
    background-color: darkred;
  }
}
@container style(--status: warning) {
  .status {
    background-color: orange;
  }
}

此时,就可以得到类似下图的渲染效果:

容器变量背景色

想要查看完整CSS代码,您可以狠狠地点击这里:CSS容器样式查询基本使用demo

指定容器名称

如果有多个容器,用了同样的变量名称,那么上面的案例可能就有冲突的问题。

此时,我们可以通过给容器命名的方式进行处理。

请看案例。

<section class="card" style="--status: success;">
  <div class="status">卡片成功</div>
</section>
<section class="toast" style="--status: success;">
  <div class="status">提示成功</div>
</section>

以上两个<section>元素设置的变量是一样的,子元素也是一样的,此时想要有所区别,就需要使用container-name属性,CSS代码参考:

.card {
  container-name: card;   
}
.toast {
  container-name: toast;    
}
@container card style(--status: success) {
  .status {
    background-color: green;
  }
}
@container toast style(--status: success) {
  .status {
    background-color: #000;
    &::after {
      content: '√';
      margin-left: .5ch;
    }
  }
}

此时,就有如下截图所示的渲染效果:

不同名称的容器查询

同样的,也演示页面,您可以狠狠地点击这里:CSS容器名称精确匹配样式查询demo

二、再看下范围解析语法

单纯的CSS变量匹配并不能让开发人员兴奋,因为,通过属性选择器,某种意义上也是可以对CSS变量进行匹配的,例如:

.toast[style*="--status: success"] {
  /* 子元素巴拉巴拉…… */
}

但是,下面这个范围解析语法,一定会让你双眼放光。

举个简单的例子,不同的分数显示不同的颜色。

90分以上是金色,金色传说。
80分以上是绿色,60~80橙色,60分以下是红色。

则无需JS判断,CSS就能处理。

HTML如下所示:

<span class="score" style="--score: 95;">
  <data>95</data>
</span>
<span class="score" style="--score: 85;">
  <data>85</data>
</span>
<span class="score" style="--score: 65;">
  <data>65</data>
</span>
<span class="score" style="--score: 35;">
  <data>35</data>
</span>

此时,就可以在style()函数中,使用大于号,小于号进行匹配,代码来咯:

@container style(--score >= 90) {
  data {
    color: gold;
  }
}
@container style(--score >= 80) and style(--score < 90) {
  data {
    color: green;
  }
}
@container style(--score >= 60) and style(--score < 80) {
  data {
    color: orange;
  }
}
@container style(--score < 60) {
  data {
    color: red;
  }
}

通俗易懂,三岁小孩也能知道是什么意思。

效果图参考:

数字,金色传说

同样的,这个例子也有演示页面,您可以狠狠地点击这里:CSS样式查询range范围匹配分数颜色demo

四、其实使用普通属性也是可以的

Chrome浏览器已经支持全属性attr()函数语法了,所以,样式匹配的时候,普通属性也是可以支持的。

例如:

<span class="score" data-score="95">
  <data>95</data>
</section>
<span class="score" data-score="85">
  <data>85</data>
</section>
<span class="score" data-score="65">
  <data>65</data>
</section>
<span class="score" data-score="35">
  <data>35</data>
</section>
.score {
  --score: attr(data-score type(<number>));
}
@container style(--score >= 90) {
  data {
    color: gold;
  }
}
/* 这部分代码都是一样的,略 */

最终的效果效果是一样的:

数字,金色传说

五、我想匹配容器自身

只要是@container容器匹配,无论是尺寸查询、样式查询、滚动查询还是锚点查询,都是只能对后代元素进行设置,容器本身是无法直接匹配。

但是,对于样式查询而言,是有曲线救国的方案的,那就是使用 if() 函数。

所以,上面的分数高亮案例,HTML代码可以进一步简化:

<data class="score" value="95"></data>
<data class="score" value="85"></data>
<data class="score" value="65"></data>
<data class="score" value="35"></data>

更语义,更原生,更简洁。

CSS代码同样简单了很多:

.score {
  --score: attr(value type(<number>));
  &::before {
    content: attr(value);
  }
  color: if(
    style(--score >= 90): gold;
    style(--score >= 80): green;
    style(--score >= 60): orange;
    else: red;
  );
}

还是相当nice的!

if函数实现的数字颜色

如果您正在使用的是Chrome浏览器,那么您可以狠狠地点击这里:CSS样式查询if()函数匹配容器自身

六、样式查询也支持尺寸设置

style()函数里面也可以设置min-width,或者height等尺寸设置。

例如:

@container style(min-width: 200px) { … }

由于@container本身就支持尺寸查询,故而这个不可替代性一般,其典型应用还是CSS变量匹配。

哦呵呵~

七、2025年就这样结束啦

2025年就这样结束啦,这一年前端依然在不断进步,如果大家注意看我的更新的新特性,7~8成都是CSS新特性,倒不是我刻意筛选,真特么就是CSS特性比DOM和JS特性多。

2024年年底的时候,绝对想不到CSS会有上面这样的写法。

要是这一年不跟着学习。

CSS就会变成你不认识的样子。

相比之下,JavaScript还是当年的样子,满屏的Promise,async和await和箭头函数,其他大同小异。

CSS则是从书写到特性都大变样了。

展望2026,新的一年,还是要持续学习的啦,加油!

加油!

本文为原创文章,会经常更新知识点以及修正一些错误,因此转载请保留原出处,方便溯源,避免陈旧错误知识的误导,同时有更好的阅读体验。
本文地址:https://www.zhangxinxu.com/wordpress/?p=11975

(本篇完)

🔲 ☆

这个有点屌CSS @container scroll-state容器滚动查询

by zhangxinxu from https://www.zhangxinxu.com/wordpress/?p=11807
本文可全文转载,但需要保留原作者、出处以及文中链接,AI抓取保留原文地址,任何网站均可摘要聚合,商用请联系授权。

滚动容器查询封面图

一、温故而知新

在学习本文的scroll-state容器滚动查询之前,大家需要先了解CSS @container容器查询。

详见我之前的文章:“介绍2022年最期待的CSS container容器查询”。

这东西可以检测容器尺寸,并进行响应的布局调整,很强大。

现在,@container容器查询,再次进化,可以识别滚动边缘,让CSS的交互能力更上一层楼。

二、scroll-state容器滚动查询

学习一个新特性最快的方法就是案例。

需求这样的,一段文本,需要用户滚动到底部,提交按钮的禁用样式才会取消。

则我们可以这么处理,HTML如下所示:

<div class="container">
  <p>作者</p>
  <p>zhangxinxu</p>
  ...
  <p>作者</p>
  <p>zhangxinxu</p>
  <footer>
    <button>提交</button>
  </footer>
</div>

CSS如下所示(已省略部分无关键要的代码):

.container {
  height: 300px;
  border: 1px solid;
  container-type: scroll-state;
  overflow: auto;
  /* 底部黏性定位 */
  footer {
    background: #f6f6f6;
    position: sticky;
    bottom: 0;
    text-align: center;
  }
  button {
    width: 100px;
    height: 32px;
    border-radius: 12px;
    background-color: crimson;
    color: white;
    cursor: pointer;
  }
}
@container scroll-state(scrollable: bottom) {
  /* 如果容器可以滚动,则按钮样式禁用 */
  button {
    filter: grayscale(1);
    opacity: .35;
  }
}

实时渲染效果如下所示(Chrome 133+ 浏览器有效果):

作者

zhangxinxu

作者

zhangxinxu

作者

zhangxinxu

作者

zhangxinxu

作者

zhangxinxu

作者

zhangxinxu

作者

zhangxinxu

或者参考下面的GIF动图演示效果:

滚动效果示意

如何使用?

第一步

给滚动容器设置 container-type: scroll-state CSS声明。

第二步

使用@container容器查询判断滚动容器是否可以上下滚动,并进行对应的CSS样式设置。

就这么简单!

无语哥

三、scroll-state查询语法

scroll-state()查询函数支持下面三种类型:

  • scrollable

    当前容器是否可以可滚动(滚动边缘)。

  • snap

    是否滚动到Snap边缘

  • stuck

    查询位置值为sticky的容器是否粘在其滚动容器祖先的边缘。

我觉得这三种都还是挺实用的。

方向值

scrollable是最常用的,我们使用scrollable参数介绍下方位值。

scroll-state(scrollable: value)

其中,value可以是(示意三种类型):

  • top: 上边缘。
  • inline-end: 内联方向边缘,默认是水平方向。
  • y: 垂直方向边缘。

我们用的比较多的就是 topbottom 了。

四、兼容性以及渔获展示

目前滚动容器查询Chrome浏览器支持,兼容性如下图所示:

scroll-state的兼容性

目前还无法大规模使用。

—-

上周末继续探钓。

周六,先是奉贤龙泉钓场,混养塘新塘新水,150元6小时,前三个小时钓法不对路,等于空军,后面三个小时散炮打浮,钓了接近30斤鱼,其中三条花鲢(当场回塘),成功挽尊。
周日去了浦东航头镇的航盛钓场,138元6小时,钓下来都是工程鲫,全场就我一个人,结果口还不错,提前收杆的情况下47斤,成功上岸盘老板。

渔获展示

😉😊😇
🥰😍😘

本文为原创文章,会经常更新知识点以及修正一些错误,因此转载请保留原出处,方便溯源,避免陈旧错误知识的误导,同时有更好的阅读体验。
本文地址:https://www.zhangxinxu.com/wordpress/?p=11807

(本篇完)

🔲 ☆

这个有点屌CSS @container scroll-state容器滚动查询

by zhangxinxu from https://www.zhangxinxu.com/wordpress/?p=11807
本文可全文转载,但需要保留原作者、出处以及文中链接,AI抓取保留原文地址,任何网站均可摘要聚合,商用请联系授权。

滚动容器查询封面图

一、温故而知新

在学习本文的scroll-state容器滚动查询之前,大家需要先了解CSS @container容器查询。

详见我之前的文章:“介绍2022年最期待的CSS container容器查询”。

这东西可以检测容器尺寸,并进行响应的布局调整,很强大。

现在,@container容器查询,再次进化,可以识别滚动边缘,让CSS的交互能力更上一层楼。

二、scroll-state容器滚动查询

学习一个新特性最快的方法就是案例。

需求这样的,一段文本,需要用户滚动到底部,提交按钮的禁用样式才会取消。

则我们可以这么处理,HTML如下所示:

<div class="container">
  <p>作者</p>
  <p>zhangxinxu</p>
  ...
  <p>作者</p>
  <p>zhangxinxu</p>
  <footer>
    <button>提交</button>
  </footer>
</div>

CSS如下所示(已省略部分无关键要的代码):

.container {
  height: 300px;
  border: 1px solid;
  container-type: scroll-state;
  overflow: auto;
  /* 底部黏性定位 */
  footer {
    background: #f6f6f6;
    position: sticky;
    bottom: 0;
    text-align: center;
  }
  button {
    width: 100px;
    height: 32px;
    border-radius: 12px;
    background-color: crimson;
    color: white;
    cursor: pointer;
  }
}
@container scroll-state(scrollable: bottom) {
  /* 如果容器可以滚动,则按钮样式禁用 */
  button {
    filter: grayscale(1);
    opacity: .35;
  }
}

实时渲染效果如下所示(Chrome 133+ 浏览器有效果):

作者

zhangxinxu

作者

zhangxinxu

作者

zhangxinxu

作者

zhangxinxu

作者

zhangxinxu

作者

zhangxinxu

作者

zhangxinxu

或者参考下面的GIF动图演示效果:

滚动效果示意

如何使用?

第一步

给滚动容器设置 container-type: scroll-state CSS声明。

第二步

使用@container容器查询判断滚动容器是否可以上下滚动,并进行对应的CSS样式设置。

就这么简单!

无语哥

三、scroll-state查询语法

scroll-state()查询函数支持下面三种类型:

  • scrollable

    当前容器是否可以可滚动(滚动边缘)。

  • snap

    是否滚动到Snap边缘

  • stuck

    查询位置值为sticky的容器是否粘在其滚动容器祖先的边缘。

我觉得这三种都还是挺实用的。

方向值

scrollable是最常用的,我们使用scrollable参数介绍下方位值。

scroll-state(scrollable: value)

其中,value可以是(示意三种类型):

  • top: 上边缘。
  • inline-end: 内联方向边缘,默认是水平方向。
  • y: 垂直方向边缘。

我们用的比较多的就是 topbottom 了。

四、兼容性以及渔获展示

目前滚动容器查询Chrome浏览器支持,兼容性如下图所示:

scroll-state的兼容性

目前还无法大规模使用。

—-

上周末继续探钓。

周六,先是奉贤龙泉钓场,混养塘新塘新水,150元6小时,前三个小时钓法不对路,等于空军,后面三个小时散炮打浮,钓了接近30斤鱼,其中三条花鲢(当场回塘),成功挽尊。
周日去了浦东航头镇的航盛钓场,138元6小时,钓下来都是工程鲫,全场就我一个人,结果口还不错,提前收杆的情况下47斤,成功上岸盘老板。

渔获展示

😉😊😇
🥰😍😘

本文为原创文章,会经常更新知识点以及修正一些错误,因此转载请保留原出处,方便溯源,避免陈旧错误知识的误导,同时有更好的阅读体验。
本文地址:https://www.zhangxinxu.com/wordpress/?p=11807

(本篇完)

❌