首页 > 其他分享 >CSS 容器查询 CSS Container Queries

CSS 容器查询 CSS Container Queries

时间:2024-07-23 21:07:49浏览次数:19  
标签:容器 container 样式 元素 查询 Queries Container CSS size

CSS 容器查询的主要思想是将一个元素注册为“容器”,并在容器元素满足某些条件时将样式应用于其他元素。

 

容器查询通常被认为是响应式网页设计的一种现代方法,其中传统媒体查询长期以来一直是黄金标准 - 原因是我们可以创建由响应容器宽度而不是视口宽度的元素组成的布局。

.parent {
  container-name: hero-banner;
  container-type: inline-size;

  /* or container: hero-banner / inline-size; */
}

}

.child {
  display: flex;
  flex-direction: column;
}

/* When the container is greater than 60 characters... */
@container hero-banner (width > 60ch) {
  /* Change the flex direction of the .child element. */
  .child { 
    flex-direction: row;
  }
}

将元素注册为容器

.cards {
  container-name: card-grid;
  container-type: inline-size;

  /* Shorthand */
  container: card-grid / inline-size;
}

此示例注册了一个名为的新容器card-grid,可以通过其 进行查询inline-size,这是在水平书写模式下表示其“宽度”的一种奇特方式。它是一个逻辑属性。否则,“inline”将指垂直书写模式下容器的“高度”。

  • container-name属性用于将元素注册为容器,并根据容器的大小和样式将样式应用于其他元素。
  • container-type属性用于将一个元素注册为一个容器,当满足某些条件时,可以将样式应用于其他元素。
  • 属性是将和属性组合成单个声明container的简写。container-namecontainer-type

查询容器

@container my-container (width > 60ch) {
  article {
    flex-direction: row;
  }
}
  • at @container-rule 属性通知浏览器我们正在使用容器查询,而不是媒体查询(即@media)。
  • 其中的my-container部分指的是容器的名称,如容器的container-name属性中所声明的。
  • 元素article代表容器中的项目,无论它是容器的直接子元素还是进一步的祖先元素。无论哪种方式,元素都必须位于容器中,并且当查询条件匹配时,它将获得应用于它的样式。

容器查询属性和值

container-name: none | <custom-ident>+;
  • none: 元素没有容器名称。默认情况下,这是正确的,因此您可能永远不会使用此值,因为它的目的纯粹是设置属性的默认行为。
  • <custom-ident>: 这是容器的名称,可以是任何名称,除了为其他功能保留的字词,包括 default、  none、  at、 no和 or。请注意,名称不包含在引号中。
container-type: normal | size | inline-size;

  

  • normal: 这表示元素是一个容器,可以通过其样式而不是大小进行查询。 从技术上讲,所有元素默认都是容器,因此我们甚至不需要明确分配 container-type 来定义样式容器。
  • size: 如果我们想根据大小查询容器,无论我们谈论的是内联方向还是块方向。
  • inline-size: 这允许我们通过其内联大小来查询容器,这相当于 标准水平书写模式。这可能是最常用的值,因为我们可以根据元素大小而不是视口大小(如我们通常使用媒体查询width 时所做的那样)来建立响应式设计 。
container: <'container-name'> [ / <'container-type'> ]?

  如果 <'container-type'> 省略,则将其重置为初始值, normal该值定义样式容器而不是大小容器。换句话说,所有元素默认都是样式容器,除非我们明确将属性 container-type 值设置为 size 或, inline-size 这允许我们查询容器的大小尺寸。

容器宽度和高度单位

单元姓名相当于…
cqw 容器查询宽度 查询容器宽度的 1%
cqh 容器查询高度 查询容器高度的 1%

容器逻辑方向

 

单元姓名相当于…
cqi 容器查询内联大小 查询容器的内联大小的 1%,即水平书写模式下的宽度。
cqb 容器查询块大小 查询容器的内联大小的 1%,即水平书写模式下的高度。

容器最小和最大长度

单元姓名相当于…
cqmin 容器查询最小尺寸 cqi或 的值cqb,以较小者为准。
cqmax 容器查询最大大小 cqi或 的值cqb,取较大者。

 

容器样式查询

size容器样式查询是 CSS 容器查询拼图的另一部分。我们不必通过或来查询容器inline-size,而是可以查询容器的 CSS 样式。当容器的样式满足查询条件时,我们可以将样式应用于其他元素。这是我们长期以来在网络上想要的那种“条件”样式:如果这些样式在这里匹配,那么就在那里应用这些其他样式。

在撰写本文时,CSS 容器样式查询仅作为现代 Web 浏览器中的一项实验性功能提供,即便如此,样式查询也只能评估 CSS 自定义属性(即变量)。

注册样式容器

article {
  container-name: card;
}

  

  就是这样!实际上,除非我们需要专门针对它,否则我们甚至不需要该container-name属性。否则,我们可以完全跳过注册容器。

如果你想知道为什么没有container-type声明,那是因为所有元素都已被视为容器。这很像所有元素的position: relative默认情况;无需声明。我们声明的唯一原因container-type是我们想要 CSS 容器大小查询而不是 CSS 容器样式查询。

因此,实际上,没有必要注册容器样式查询,因为所有元素都已经是现成的样式容器!我们声明 的唯一原因container-name只是为了在编写样式查询时帮助按名称选择特定容器。

使用样式容器查询

@container style(--bg-color: #000) {
  p { color: #fff; }
}

  

  在这个例子中,我们查询任何匹配的容器(因为默认情况下所有元素都是样式容器)。

注意到它的语法与传统的媒体查询非常相似吗?最大的区别是我们写的@container是 而不是@media。另一个区别是我们调用了一个style()保存匹配样式条件的函数。这样,​​样式查询与尺寸查询就区分开来了,尽管没有相应的size()函数。

在此例中,我们检查某个自定义属性是否--bg-color设置为黑色 ( #000)。如果变量的值符合该条件,则我们将段落 ( p) 文本设置color为白色 ( #fff)。

自定义属性和变量

.card-wrapper {
  --bg-color: #000;
}
.card {
  @container style(--bg-color: #000) {
    /* Custom CSS */
  }
}

  

嵌套样式查询

@container style(--featured: true) {
  article {
    grid-column: 1 / -1;
  }
  @container style(--theme: dark) {
    article {
      --bg-color: #000;
      --text: #fff;
    }
  }
}

  

标签:容器,container,样式,元素,查询,Queries,Container,CSS,size
From: https://www.cnblogs.com/zzg1022/p/18319642

相关文章

  • CSS 动画专题
    0x01过渡transition过渡(transition)是应用于特定元素的CSS属性,在指定时间内平滑过渡到目标样式(1)必要属性使用transition-property指定需要过渡的CSS属性可以列入一个或多个CSS属性也可以使用all值,表示所有变化的CSS属性都需要过渡仅可以用于过渡的值是可以......
  • css 蛇形排序
    先看效果需求:一个【4 *?】的网格布局,奇数行布局从左往右,偶数行布局从右往左。思路1:js将数组按4个每份进行分割,将偶数份进行反向,然后再将分割后的数据,重新组装。(太麻烦,劝退。)思路2:flex布局,然后用order属性来更改排列顺序。补充:or......
  • html+css 简易摩天轮效果
    vuedom<divclass="ferris_wheel"><divclass="wheelBg"></div><divclass="wheelBox"><divclass="bg"></div><ulclass="list">......
  • Tailwind CSS 实现响应式布局
    TailwindCSS实现响应式布局CSS3如何实现响应式先聊聊纯CSS方案是怎么做的:使用CSS3特性:@mediascrren表示设备屏幕,and用于并列多个条件一般来讲每个响应式系统的ui规范都要有多个断点:small:640px起,横向模式显示状态的手机medium:768px起,平板large:1024px起,电脑......
  • HTML5+CSS3学习笔记第二天
    二、HTML第二天(列表、表格、表单)1.列表无序列表:每行前面多一个小点<ul><li>列表条目1</li><li>列表条目2</li><li>列表条目3</li></ul>有序列表:每行前面自动加1.2.3.的序号<ol><li>有序列表条目1</li><li>有序列表条......
  • HTML5+CSS3学习笔记第一天
    一、HTML初体验11.HTML定义:超文本标记语言超文本:链接标记:标签、带尖括号的文本2.标签语法双标签:成对出现,中间包裹内容单标签:只有开始标签eg:水平线hr、换行br<>放英文字母即标签名结束标签多一个/3.HTML基本骨架<html> <head> <title>网页标题</title> </head>......
  • 在 Django 表单中使用正确的 Bootstrap CSS 进行单选表单输入
    如何让Django表单将正确的Bootstrap渲染到Radioselect表单输入?我在表单中传递了form-controlform-checkclassess,但生成的表单HTML对于radioselect选项并不准确。我正在寻找渲染引导程序原色和内联单选按钮。表单classPersonForm(forms.Form......
  • 一文掌握 Tailwind CSS 基础
    一文掌握TailwindCSS基础工欲善其事,必先利其器先推荐一些好用的工具:TailWindCSS代码提示功能的vscode插件:TailwindCSSIntelliSense再推荐一个TailwindCSS速查网站:https://tailwind.muzhifan.top/本文假定读者已经有一定的CSS基础1宽高1.使用预定义类名如......
  • 04 CSS 轮播图无缝滚动
    <!DOCTYPEhtml><htmllang="en"><head><metacharset="UTF-8"><metahttp-equiv="X-UA-Compatible"content="IE=edge"><metaname="viewport"content="width=......
  • 389.权志龙明星主题网页 大学生期末大作业 Web前端网页制作 html5+css+js
    欢迎光临仙女的网页世界!这里有Web前端网页制作的各行各业的案例,样式齐全新颖,并持续更新!感谢CSDN,提供了这么好的知识学习、技术交流的平台,让我们在这里相遇,小伙伴们,来吧,让我们一起开启Web前端网页制作的奇妙之旅!说起Web前端,大学开启这扇技术之门以来,一切起始于兴趣爱好和......