목차
1、CSS Subgrid
浏览器支持情况
2、Flexbox gaps
🎜1. CSS Subgrid🎜
🎜브라우저 지원🎜
3、content-visibility 属性
浏览器支持
4、contain-intrinsic-size 属性
5、:is:where 伪类
总结
웹 프론트엔드 CSS 튜토리얼 이미 사용해 볼 수 있는 5가지 새로운 CSS 기능

이미 사용해 볼 수 있는 5가지 새로운 CSS 기능

May 21, 2021 am 10:00 AM
CSS의 새로운 기능

이 글에서는 5가지 새로운 CSS 기능을 소개합니다. 도움이 필요한 친구들이 모두 참고할 수 있기를 바랍니다.

이미 사용해 볼 수 있는 5가지 새로운 CSS 기능

새로운 CSS 기능은 브라우저가 구현을 시작하기 전에 오랜 논의 끝에 W3컨소시엄 사양에 정의되어야 하는 경우가 많습니다. 언급할 만한 새로운 CSS 기능이 많이 있지만 이 기사에서는 브라우저의 안정 버전에서 테스트할 수 있는 5가지 기능에 중점을 둡니다.

  • CSS Subgrid

  • flex gaps

  • 콘텐츠 가시성 속성 content-visibility 属性

  • contains-intrinsic-size 属性

  • :is:where 伪类

浏览器对这些特性的支持一直在变化,可以通过 Can I Use 来查看支持情况。

1、CSS Subgrid

CSS 网格是一个灵活的布局模块,允许开发人员创建复杂的布局,无需使用JavaScript或使用复杂的 CSS hack

使用 CSS 网格的语法很简单,如下所示:

.grid-container {
    display: grid;
}
로그인 후 복사

可以使用几个特定于网格的属性来设置所需的确切布局。

例如,在上面的示例中,.grid-container的子元素将是网格项,它们将根据使用grid-template-columnsgrid-template-rows属性定义的规则进行布局:

.grid-container {
    display: grid;
    grid-template-columns: 1fr 2fr 1fr;
    grid-template-rows: 50px 70vh 50px;
}
로그인 후 복사

运行结果如下:

이미 사용해 볼 수 있는 5가지 새로운 CSS 기능

但是,如果你也想在网格布局中包括.grid-container的某些(或全部)子孙元素怎么办? 这就是CSS Subgrid 发挥作用的地方。

可以向网格项目添加以下规则,以使其能够采用其父级的网格轨道(包括名称网格线和区域,即使它也可以定义自己的网格轨道和区域)。

.grid-item {
    /* 这些规则指定子网格在布局中的位置*/
    grid-column: 2 / 4;      /* 两列垂直 */
    grid-row: 1 / 3;         /* 两行水平 */

    /* 这些规则属于子网格本身 */
    display: grid;
    grid-template-columns: subgrid;
    grid-template-rows: subgrid;
}
로그인 후 복사

grid-columngrid-row属性定义了网格项目在网格列或行中的位置。 .grid-item的子元素将形成子网格。 一个网格项目可以跨越多个网格单元。 例如,这里它分布在四个像元上(在上面的示例中grid-columngrid-row的值是任意的)。

如上所见,subgrid 不是独立的CSS属性,而是可以添加到grid-template-columnsgrid-template-rows属性的值。 它使.grid-item的子级包含在网格布局中:

이미 사용해 볼 수 있는 5가지 새로운 CSS 기능

子网格已成为网格布局的一部分,并且已定位到我们想要的确切位置(在第二和第四条垂直网格线之间,以及在第一和第三条水平网格线之间)。

其余的网格项目保持了正常的网格流,第四行也出现在布局的底部。 但是,由于我们仅使用grid-template-rows属性定义了三行,因此第四行没有预设值,因此仅取其内容的自然高度。 如果我们要从最后三个网格项目中删除文本,则它们甚至不会显示,因为它们的自然高度为0

可以使用下面的CodePen演示来测试上面的示例。

https://codepen.io/amonus/pen/dyMgeLP

我们也可以通过仅采用grid-template-columnsgrid-template-rows并为另一项使用新值来创建一维子网格。

例如,在以下情况下,子网格仅采用主网格的列,但为行创建新规则

.grid-item {
  display: grid;
  grid-template-columns: subgrid;
  grid-template-rows: 200px 400px 200px;
}
로그인 후 복사

浏览器支持情况

自2020年8月起,CSS 子网格规范已成为W3C的候选推荐标准。目前,Firefox 71+仅支持该子网格规范,但开源 Web 浏览器 Chromium 也已开始使用它,该浏览器被用作主要浏览器(包括Chrome,Opera, Brave,以及新的Microsoft Edge。

2、Flexbox gaps

长期以来,在 felx 布局中的之间添加间隙一直是一个难题。 通常可以通过在 flex 项目中添加 margin 来解决问题,但是margin的问题在于,它们也会被添加到每个的开头和结尾。 即使可以通过 CSS 来解决这些缺陷,但这也不是最理想的解决方案。

目前,浏览器对flexbox gap 的支持越来越好。 gaprow-gapcolumn-gap 属性存在于不同的上下文中,具有不同级别的浏览器支持。 我们可以在以下布局模块中使用gap

🎜🎜contains-intrinsic-size 속성 🎜🎜🎜🎜:is:where 유사- class 🎜🎜🎜이 기능에 대한 브라우저 지원은 지속적으로 변경되고 있습니다. Can I Use를 통해 지원 상태를 확인할 수 있습니다. 🎜

🎜1. CSS Subgrid🎜

🎜CSS Grid는 개발자가 JavaScript를 사용하거나 복잡한 🎜CSS 해킹🎜을 사용하지 않고도 복잡한 레이아웃을 만들 수 있는 유연한 레이아웃 모듈입니다. 🎜🎜CSS 그리드를 사용하는 구문은 간단하며 다음과 같습니다. 🎜
.flex-container {
  row-gap: 10px;
  column-gap: 15px;
}
로그인 후 복사
로그인 후 복사
🎜원하는 정확한 레이아웃을 설정하는 데 사용할 수 있는 그리드 관련 속성이 몇 가지 있습니다. 🎜🎜예를 들어 위 예에서 .grid-container의 하위 요소는 그리드 항목이 되며 grid-template-columns 사용을 기반으로 합니다. grid-template-rows 속성은 규칙을 레이아웃하는 데 사용됩니다. 🎜
.flex-container {
  gap: 10px 15px;
}
로그인 후 복사
로그인 후 복사
🎜실행 결과는 다음과 같습니다. 🎜🎜이미 사용해 볼 수 있는 5가지 새로운 CSS 기능🎜🎜그러나 .grid-container의 일부도 포함하려는 경우 code> 그리드 레이아웃(또는 모두)의 하위 요소는 어떻습니까? 이것이 🎜CSS Subgrid🎜가 작동하는 곳입니다. 🎜🎜다음 규칙을 그리드 항목에 추가하여 상위 그리드 트랙(자체 그리드 트랙 및 영역을 정의할 수도 있지만 이름 그리드 선 및 영역 포함)을 채택할 수 있습니다. 🎜
.flex-container {
  gap: 10px;
}
로그인 후 복사
로그인 후 복사
🎜 grid-columngrid-row 속성은 그리드 열이나 행에서 그리드 항목의 위치를 ​​정의합니다. .grid-item의 하위 요소는 하위 그리드를 형성합니다. 그리드 항목은 여러 그리드 셀에 걸쳐 있을 수 있습니다. 예를 들어 여기서는 4개의 셀에 분산되어 있습니다(위 예에서 grid-columngrid-row 값은 임의적임). 🎜🎜위에서 볼 수 있듯이 subgrid는 독립적인 CSS 속성이 아니지만 grid-template-columnsgrid-template-rows</code에 추가할 수 있습니다. > 속성의 값입니다. 그리드 레이아웃에 포함된 <code>.grid-item의 하위 항목을 만듭니다. 🎜🎜이미 사용해 볼 수 있는 5가지 새로운 CSS 기능🎜🎜하위 그리드는 그리드 레이아웃의 일부가 되었으며 정확히 원하는 위치에 배치되었습니다(세로 그리드 선 사이의 두 번째와 네 번째, 첫 번째와 세 번째 수평 격자선 사이). 🎜🎜나머지 그리드 항목은 일반적인 그리드 흐름을 유지하며, 네 번째 행도 레이아웃 하단에 나타납니다. 그러나 grid-template-rows 속성을 ​​사용하여 정의된 행은 3개뿐이므로 네 번째 행에는 기본값이 없으므로 단순히 내용의 자연스러운 높이를 사용합니다. 마지막 세 개의 그리드 항목에서 텍스트를 제거하면 원래 높이가 0이므로 표시되지도 않습니다. 🎜
🎜위 예제는 아래 CodePen 데모를 사용하여 테스트할 수 있습니다. 🎜🎜https://codepen.io/amonus/pen/dyMgeLP🎜
🎜 grid-template-columns 또는 grid-template-rows</ 코드만 사용할 수도 있습니다. > 다른 항목에 대한 새 값을 사용하여 1D 하위 그리드를 만듭니다. 🎜🎜예를 들어 다음과 같은 경우 하위 그리드는 기본 그리드의 열만 가져오지만 행에 대한 새로운 규칙을 만듭니다. 🎜<div class="code" style="position:relative; padding:0px; margin:0px;"><div class="code" style="position:relative; padding:0px; margin:0px;"><pre class='brush:php;toolbar:false;'>article { content-visibility: auto; }</pre><div class="contentsignin">로그인 후 복사</div></div><div class="contentsignin">로그인 후 복사</div></div><h4 id="브라우저-지원">🎜브라우저 지원🎜</h4>🎜2020년 8월 기준 CSS 하위 그리드 사양은 W3C 후보 권장 사항이 되었습니다. 현재 Firefox 71+에서는 이 서브그리드 사양만 지원하지만, 메인 브라우저로 사용되는 오픈소스 웹 브라우저 Chromium(Chrome, Opera, Brave 및 새로운 Microsoft Edge 포함)에서도 사용되기 시작했습니다. 🎜< h2>🎜2, Flexbox gaps🎜</h2>🎜 Felx 레이아웃에서 <code>행 또는 사이에 간격을 추가하는 것은 오랫동안 문제가 되어 왔으며 일반적으로 를 추가하는 것이 가능합니다. flex 항목의 margin을 사용하면 문제가 해결되지만 margin의 문제는 모든 line 또는 에도 추가된다는 것입니다. 열. CSS를 통해 이러한 결함을 해결할 수 있다고 해도 이는 가장 이상적인 솔루션은 아닙니다. 🎜🎜현재 flexbox gap에 대한 브라우저 지원은 증가하고 있습니다. , row-gapcolumn-gap 속성은 다양한 브라우저 지원 수준과 함께 다양한 컨텍스트에 존재합니다. 다음 레이아웃 모듈 🎜.
  • 声明 display: flex; 的模块
  • 声明 display: grid; 的模块
  • 多列布局,由column-countcolumn-width属性定义

flexbox上下文中,我们可以这里声明 flex 项目之前的间距:

.flex-container {
  row-gap: 10px;
  column-gap: 15px;
}
로그인 후 복사
로그인 후 복사

gap属性是row-gapcolumn-gap的简写。 如果将它与两个值一起使用,则第一个表示row-gap,第二个表示column-gap

.flex-container {
  gap: 10px 15px;
}
로그인 후 복사
로그인 후 복사

如果仅使用一个值,则row-gapcolumn-gap将采用相同的值。

.flex-container {
  gap: 10px;
}
로그인 후 복사
로그인 후 복사

浏览器支持情况

Edge 84+Firefox 63+Chrome 84+Opera 70+当前支持 gap属性。 Internet Explorer 和 Safari 目前还不支持它。

3、content-visibility 属性

在Chromium 85中,content-visibility属性可能是在提高页面加载性能方面最具影响力的新CSS属性之一。因为content-visibility可跳过不在屏幕上的内容渲染,包括布局和渲染,直到真正需要布局渲染的时候为止。所以利用它可以使初始用户加载速度更快,还能与屏幕上的内容进行更快的交互。

它有三个值:

  • visible — 元素渲染正常进行
  • hidden— 跳过元素渲染时,无论是在屏幕外还是在屏幕上
  • auto — 当元素在屏幕外时,将跳过其渲染; 当它出现在屏幕上时,将自动渲染

可以简单地将content-visibility属性添加到我们希望更改其渲染过程的元素中。

article {
  content-visibility: auto;
}
로그인 후 복사
로그인 후 복사

一个具有content-visibility: auto属性的元素可以获得布局、样式和绘制的限制(区域)。如果该元素不在屏幕上(并且与用户无关,则相关元素将是在其子树中具有焦点或已选择的元素),它也会获得大小限制(containment)(并且停止绘制和对其内容进行命中测试)。

这意味着什么呢?简而言之,如果元素不在屏幕上,这不会渲染其后代。浏览器在不考虑元素任何内容的情况下确定元素的大小,在此处则跳过大多数渲染(例如元素子树的样式和布局)。

当元素接近视口时,浏览器不再增加大小限制,而是开始绘制并命中测试元素的内容。这使得渲染工作能够及时被用户看到。

浏览器支持

content-visibility依赖于CSS Containement Spec中的原语(primitives)。虽然截止到目前只有Chromium 85中支持content-visibility属性(and deemed "worth prototyping" for Firefox),但是大多数现代浏览器均支持Containement Spec。

4、contain-intrinsic-size 属性

contains-intrinsic-size属性定义激活大小限制的元素的显式宽度和高度,这意味着元素的大小不受子元素大小的影响。 设置明确的宽度和高度旨在防止这些元素在某些情况下崩溃为零

为了实现content-visibility的潜在好处,浏览器需要应用大小限制,以确保内容的呈现结果不会被任何方式影响元素的大小。 如果元素没有在常规块布局中指定的高度,则其高度为0

这可能不是理想的,因为滚动条的大小会发生变化,这取决于每个具有非零高度的内容。

所以, CSS 提供了另一个属性contains-intrinsic-size,如果元素受大小限制影响,它可以有效地指定元素的自然大小。

article {
  content-visibility: auto;
  contain-intrinsic-size: 700px 1000px;
}
로그인 후 복사

浏览器支持情况

目前Chrome 83+,和支持contains-intrinsic-size`属性, Firefox不支持。

5、:is:where 伪类

:is() CSS 伪类 函数将选择器列表作为参数,并选择该列表中任意一个选择器可以选择的元素。这对于以更紧凑的形式编写大型选择器非常有用。

:where() CSS 伪类函数接受选择器列表作为它的参数,将会选择所有能被该选择器列表中任何一条规则选中的元素。

:where():is() 的不同之处在于,:where() 的优先级总是为 0 ,但是 :is() 的优先级是由它的选择器列表中优先级最高的选择器决定的。

例如,有以下选择器列表:

.my-class p em,
.my-class li em,
.my-class section em {
    // CSS rules
}
로그인 후 복사

如果要保持较高的优先级,以使其更难以用后续声明覆盖所属规则,则可以使用:is()缩短列表。

.my-class :is(p, li, section) em {
  // CSS rules
}
로그인 후 복사

如果我们希望将优先级保持为0以方便重写所属规则,那么可以使用:where()

.my-class :where(p, li, section) em {
  // CSS rules
}
로그인 후 복사

在上面的示例中,.my-class em选择器将覆盖:where规则,但不会覆盖:is

浏览器支持情况

:is伪类目前被Firefox 78+Safari 14+支持。基于 Chrome 的浏览器(Chrome 15+、Edge 79+、Opera 15+)使用:-webkit-any()前缀支持其前缀语法。你也可以通过设置试验性的网络平台特性标志来启用该功能:在Chrome 68+Opera 55+Edge 79+中选中。

:where伪类的支持较少。 目前,只有Firefox 78+支持它。

总结

目前, 目前还需要谨慎使用本文讨论的CSS新功能。 理想情况下,使用带前缀的版本,或者等到它们得到更广泛的实行。

但是,如果你想进行测试,则可以使用content-visibilitycontains-intrinsic-size属性。 你可以在已经支持该功能的浏览器中实现性能上的优化(可以使用@supports规则测试浏览器支持),并且不会影响尚不支持该功能的浏览器。

总而言之,CSS新特性的标准化和实现过程值得我们不断关注。有许多有用的功能将最终使前端开发更容易和更快。

英文原文地址:https://blog.logrocket.com/5-new-css-features-you-can-already-test/

作者: Anna Monus

译文地址:https://segmentfault.com/a/1190000040031049

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

위 내용은 이미 사용해 볼 수 있는 5가지 새로운 CSS 기능의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

인기 기사

R.E.P.O. 에너지 결정과 그들이하는 일 (노란색 크리스탈)
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 최고의 그래픽 설정
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 아무도들을 수없는 경우 오디오를 수정하는 방법
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25 : Myrise에서 모든 것을 잠금 해제하는 방법
4 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

GraphQL 캐싱 작업 GraphQL 캐싱 작업 Mar 19, 2025 am 09:36 AM

최근에 GraphQL 작업을 시작했거나 장단점을 검토 한 경우 "GraphQL이 캐싱을 지원하지 않음"또는

첫 번째 맞춤형 전환을 만듭니다 첫 번째 맞춤형 전환을 만듭니다 Mar 15, 2025 am 11:08 AM

Svelte Transition API는 맞춤형 전환을 포함하여 문서를 입력하거나 떠날 때 구성 요소를 애니메이션하는 방법을 제공합니다.

쇼, 말하지 마십시오 쇼, 말하지 마십시오 Mar 16, 2025 am 11:49 AM

웹 사이트의 컨텐츠 프레젠테이션을 설계하는 데 얼마나 많은 시간을 소비합니까? 새 블로그 게시물을 작성하거나 새 페이지를 만들 때

Redwood.js 및 동물 군을 사용하여 이더 리움 앱 구축 Redwood.js 및 동물 군을 사용하여 이더 리움 앱 구축 Mar 28, 2025 am 09:18 AM

최근 Bitcoin의 가격이 20k 달러가 넘는 USD가 최근에 등반되면서 최근 30k를 끊었으므로 Ethereum을 만드는 데 깊이 다이빙을 할 가치가 있다고 생각했습니다.

CSS를 사용하여 텍스트 그림자 및 그라디언트와 같은 텍스트 효과를 만드는 방법은 무엇입니까? CSS를 사용하여 텍스트 그림자 및 그라디언트와 같은 텍스트 효과를 만드는 방법은 무엇입니까? Mar 14, 2025 am 11:10 AM

이 기사에서는 그림자 및 그라디언트와 같은 텍스트 효과에 CSS를 사용하여 성능을 최적화하고 사용자 경험을 향상시킵니다. 초보자를위한 리소스도 나열됩니다. (159 자)

Leakenty와 함께 자신의 Bragdoc을 만듭니다 Leakenty와 함께 자신의 Bragdoc을 만듭니다 Mar 18, 2025 am 11:23 AM

개발자로서 어느 단계에 있든, 우리가 완료 한 작업은 크든 작든, 개인적이고 전문적인 성장에 큰 영향을 미칩니다.

NPM 명령은 무엇입니까? NPM 명령은 무엇입니까? Mar 15, 2025 am 11:36 AM

NPM 명령은 서버 시작 또는 컴파일 코드와 같은 것들에 대한 일회성 또는 지속적으로 실행되는 프로세스로 다양한 작업을 실행합니다.

CI/CD에 약간 CI/CD에 약간 Apr 02, 2025 pm 06:21 PM

"웹 사이트"는 "모바일 앱"보다 더 잘 맞지만 Max Lynch 의이 프레임이 마음에 듭니다.

See all articles