作者: Anna Monus
译者:前端小智
起源:blog.logrocket
有幻想,有干货,微信搜寻 【大迁世界】 关注这个在凌晨还在刷碗的刷碗智。
本文 GitHub https://github.com/qq449245884/xiaozhi 已收录,有一线大厂面试残缺考点、材料以及我的系列文章。
在浏览器开始实现它们之前,CSS 新的性能通常须要通过长时间探讨之后,才在W3联盟的标准中定义。 有许多值得一提的 CSS 新性能,然而在本文中,咱们重点介绍能够浏览器的稳定版中进行测试的五个性能:
- 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-columns
和grid-template-rows属
性定义的规定进行布局:
.grid-container { display: grid; grid-template-columns: 1fr 2fr 1fr; grid-template-rows: 50px 70vh 50px;}
运行后果如下:
然而,如果你也想在网格布局中包含.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-column
和grid-row
属性定义了网格我的项目在网格列或行中的地位。 .grid-item
的子元素将造成子网格。 一个网格我的项目能够逾越多个网格单元。 例如,这里它散布在四个像元上(在下面的示例中grid-column
和grid-row
的值是任意的)。
如上所见,subgrid
不是独立的CSS属性,而是能够增加到grid-template-columns
和grid-template-rows
属性的值。 它使.grid-item
的子级蕴含在网格布局中:
子网格已成为网格布局的一部分,并且已定位到咱们想要的确切地位(在第二和第四条垂直网格线之间,以及在第一和第三条程度网格线之间)。
其余的网格我的项目放弃了失常的网格流,第四行也呈现在布局的底部。 然而,因为咱们仅应用grid-template-rows
属性定义了三行,因而第四行没有预设值,因而仅取其内容的天然高度。 如果咱们要从最初三个网格我的项目中删除文本,则它们甚至不会显示,因为它们的天然高度为0
。
能够应用上面的CodePen演示来测试下面的示例。
咱们也能够通过仅采纳grid-template-columns
或grid-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
的反对越来越好。 gap
,row-gap
和column-gap
属性存在于不同的上下文中,具备不同级别的浏览器反对。 咱们能够在以下布局模块中应用gap
属性。
- 申明
display: flex;
的模块 - 申明
display: grid;
的模块 - 多列布局,由
column-count
或column-width
属性定义
在flexbox
上下文中,咱们能够这里申明 flex 我的项目之前的间距:
.flex-container { row-gap: 10px; column-gap: 15px;}
gap
属性是row-gap
和column-gap
的简写。 如果将它与两个值一起应用,则第一个示意row-gap
,第二个示意column-gap
。
.flex-container { gap: 10px 15px;}
如果仅应用一个值,则row-gap
和column-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。
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-visibility
和contains-intrinsic-size
属性。 你能够在曾经反对该性能的浏览器中实现性能上的优化(能够应用@supports
规定测试浏览器反对),并且不会影响尚不反对该性能的浏览器。
总而言之,CSS新个性的标准化和实现过程值得咱们一直关注。有许多有用的性能将最终使前端开发更容易和更快。
代码部署后可能存在的BUG没法实时晓得,预先为了解决这些BUG,花了大量的工夫进行log 调试,这边顺便给大家举荐一个好用的BUG监控工具 Fundebug。
原文:https://blog.logrocket.com/5-...
交换
有幻想,有干货,微信搜寻 【大迁世界】 关注这个在凌晨还在刷碗的刷碗智。
本文 GitHub https://github.com/qq44924588... 已收录,有一线大厂面试残缺考点、材料以及我的系列文章。