CSS 容器查询

466次阅读  |  发布于2年以前

在响应式布局布局中,经常使用媒体查询(Media Queries)检测视窗的宽高,实现自元素样式的自动调整。但是在一些页面设计中,元素的容器尺寸发生变化时,元素的样式也需要随之变化。很显然,媒体查询无法支持这种场景。为了解决这类问题,CSS 增加了一个新的特性 容器查询(Container Queries)

浏览配置

目前,容器查询还没有被 Chrome 浏览器正式支持,需要手动开启容器查询功能。在 Chrome 浏览器中打开

chrome://flags/#enable-container-queries,然后找到对应配置后,将 Default 改为 Enabled

经过测试发现:

容器查询

为了支持容器查询,CSS 的新规范中增加了 container-typecontainer-namecontainer 三个属性。containercontainer-typecontainer-name 的简写属性,用来显式声明某个元素是一个查询容器,并且定义查询容器的类型(由 container-type 指定)和查询容器的名称(由 container-name 指定,使用反斜杠(/)隔开。

除此之外,要用 @container 来声明容器查询的样式,比如在下面的例子中,当 <main> 元素的宽度小于 800px 时,`元素中的字体颜色被置为gray`:

main {
  container: inline-size / name;
  /* 
  * 等价于
  * container-type: inline-size;
  * container-name: name;
  */
}

@container name (max-width: 800px) {
  span {
    color: gray;
  }
}
<main>
  <span>koofe</span>
</main>

声明了 container-type 这个属性,就意味着告诉浏览器,在该元素上创建一个容器上下文,之后可能要查询此容器。container-type 支持如下属性:

container-name 用来指定当前容器所对应的容器查询的名称,可以省略不设置该属性。@container 方法通过对被查询的元素应用大小和布局的限制来实现。任何具有尺寸和布局限制的元素都可以通过一个新的 @container 规则进行查询,其语法与现有的媒体查询类似。

示例演示

.content 元素宽度小于 800px 时,卡片布局由左图右文变为上图下文。具体代码如下:

  <div class="content">
    <div class="card">
      <div class="qrcode">
        <img src="https://s2.loli.net/2022/04/04/4VuT1aKLEZ3O6Mj.jpg" />
      </div>
      <div class="box">
        <div class="title">KooFE</div>
        <div class="about">介绍前端知识技巧,了解前端最新动态,欢迎大家关注!</div>
      </div>
    </div>
  </div>
.content {
  container-type: inline-size;
  resize: horizontal;
  overflow: hidden;
  background: #efefef;
}

.card {
  display: flex;
  width: 600px;
  margin: 8px;
  padding: 8px;
  border-radius: 4px;
  background: #ffffff;
}

.box {
  padding-left: 16px;
}

.title {
  line-height: 36px;
  font-weight: 800;
  font-size: 20px;
}

.content .about {
  padding-top: 8px;
  line-height: 24px;
  color: #666666;
}

@container (max-width: 800px) {
  .card {
    width: 200px;
    flex-direction: column;
  }
  .box {
    padding: 0;
  }
  .about {
    display: none;
  }
}

目前,容器查询的标准处于工作草案(Working Draft)阶段,绝大部分浏览器并未支持该特性,所以也无法在实践开发中进行应用。容器查询会更好的支持页面的响应式设计,并且在一定程度上能够丰富组件的样式,让组件变得更加通用。

Copyright© 2013-2020

All Rights Reserved 京ICP备2023019179号-8