在重新计算样式事件期间分析 CSS 选择器性能

性能工具突出显示右上角带有红色三角形的每个长时间运行的任务,以指示运行时间较长且性能缓慢的main线程上的工作:

main线程上性能缓慢的事件的长时间运行任务指示器

在性能记录中,其中一些长时间运行的任务可能是 “重新计算样式 ”事件。 “重新计算样式”事件跟踪浏览器执行以下操作所需的时间:

  • 循环访问页面上的 DOM 元素,以查找与给定元素匹配的所有 CSS 样式规则。
  • 根据匹配的 CSS 样式规则计算每个元素的实际样式。

每当 CSS 规则的适用性发生更改时,都需要重新计算 CSS 样式,例如:

  • 在 DOM 中添加或删除元素时。
  • 当元素的属性发生更改时,例如 或 id 属性的值class
  • 发生用户输入时,例如鼠标移动或更改网页中哪个元素具有焦点,这可能会影响 :hover 规则。

长时间运行的 “重新计算样式” 事件时,可以使用 “选择器统计信息 ”选项卡了解哪些 CSS 选择器占用的时间最多,从而导致性能降低。

“选择器统计信息”选项卡提供有关性能记录中一个或多个“重新计算样式”事件中涉及的 CSS 规则选择器的统计信息。

在启用选择器统计信息的情况下记录性能跟踪

若要查看在长时间运行的 “重新计算样式 ”事件期间 CSS 规则选择器的统计信息,请先记录启用了选择器统计信息功能的性能跟踪。 通过选中“ 启用 CSS 选择 器统计信息”复选框来启用选择器统计信息功能,其中显示“ 选择器统计信息 ”选项卡。

选择器统计信息功能并非始终启用,因为它会增加性能录制的开销。 仅当需要调查 重新计算样式 事件和其他呈现信息的性能时,才应将其保持打开状态。

使用选择器统计信息记录性能跟踪:

  1. 在新窗口或选项卡中打开网页,例如 照片库 演示页。

  2. 若要打开 DevTools,请右键单击网页,然后选择“ 检查”。 或者,按 Ctrl+Shift+I (Windows、Linux) 或 Command+Option+I (macOS) 。 DevTools 随即打开。

  3. 在 DevTools 的 “活动栏”上,选择“ 性能 (性能工具”图标) 选项卡。如果该选项卡不可见,请选择“ 更多工具 ” (“更多工具”图标) >性能”。

  4. “性能 ”工具中,单击“ 捕获设置 ” (“捕获设置”图标) 按钮。

  5. 选中 “启用 CSS 选择器统计信息 ”复选框:

    性能工具中的“启用 CSS 选择器统计信息”复选框

  6. 单击“ 记录 (”记录“图标) 按钮,然后运行要针对网站或应用改进的方案。

  7. 单击“ 停止 ”按钮。

接下来,查看 CSS 选择器统计信息,如以下部分所述。

查看单个事件的 CSS 规则选择器统计信息

若要查看单个 “重新计算样式 ”事件中涉及的 CSS 规则选择器的统计信息,请执行以下操作:

  1. 执行上述在 启用选择器统计信息的情况下记录性能跟踪中的步骤。

  2. 在性能记录中找到 “重新计算样式 ”事件,然后单击它。

  3. “性能 ”工具的底部,单击“ 选择器统计信息 ”选项卡:

    性能工具中的“选择器统计信息”选项卡

“选择器统计信息”选项卡中的 CSS 选择器表

性能工具中的“选择器统计信息”选项卡包含 CSS 选择器表。 该表显示每个 CSS 选择器的以下信息:

说明
已用 (ms) 浏览器与此 CSS 选择器匹配所用的时间。 此时间以毫秒为单位, (毫秒) ,其中 1 毫秒为 1/1000 秒。
匹配尝试 浏览器引擎尝试与此 CSS 选择器匹配的元素数。
匹配计数 浏览器引擎与此 CSS 选择器匹配的元素数。
慢速路径非匹配项的百分比 与此 CSS 选择器不匹配的元素与浏览器引擎尝试匹配的元素的比率,该比例要求浏览器引擎使用优化程度较低的代码进行匹配。
选择 匹配的 CSS 选择器。
样式表 包含 CSS 选择器的 CSS 样式表。

完成后,在 性能 工具中,单击捕获 设置 (捕获设置图标) 按钮,然后清除 “启用 CSS 选择器统计信息 ”复选框。

查看多个事件的 CSS 规则选择器统计信息

若要查看多个 “重新计算样式 ”事件中涉及的 CSS 规则选择器的聚合统计信息,请将多个 选择器统计信息 表复制到电子表格中,如下所示:

  1. 执行上述在 启用选择器统计信息的情况下记录性能跟踪中的步骤。

  2. 找到你感兴趣的第一个 “重新计算样式 ”事件,然后单击它。

  3. “性能 ”工具的底部,单击“ 选择器统计信息 ”选项卡。

  4. 右键单击选择器统计信息表,然后选择“ 复制表”:

    选择器统计信息表中的“复制表”菜单项

  5. 将表格粘贴到电子表格中,例如 Microsoft Excel。

  6. 使用你感兴趣的其他 “重新计算样式 ”事件重复上述步骤。

完成后,在 性能 工具中,单击捕获 设置 (捕获设置图标) 按钮,然后清除 “启用 CSS 选择器统计信息 ”复选框。

查看完整录制的聚合 CSS 规则选择器统计信息

若要查看整个性能记录中涉及的 CSS 规则选择器的聚合统计信息,请执行以下操作:

  1. 执行上述在 启用选择器统计信息的情况下记录性能跟踪中的步骤。

  2. 通过单击火焰图的空白区域,取消选择在性能录制中选择的任何事件。

  3. 选择整个录制范围。 为此,请双击性能工具顶部的 CPU 图表,或使用鼠标将鼠标悬停在火焰图上并向上滚动,直到显示整个图表。

  4. “性能 ”工具的底部,单击“ 选择器统计信息 ”选项卡:

    完整录制的“选择器统计信息”表

完成后,在 性能 工具中,单击捕获 设置 (捕获设置图标) 按钮,然后清除 “启用 CSS 选择器统计信息 ”复选框。

分析 CSS 选择器统计信息

若要按升序或降序对 选择器统计信息 表中显示的数据进行排序,请单击列标题。 例如,若要查看哪些 CSS 选择器占用的时间最多,请单击“ 已用 (毫秒) 列标题:

选择器统计信息表,其中 CSS 选择器按运行时间按降序排序

若要尝试提高网页的性能,请关注以下 CSS 选择器:

  • 计算) 值) (高 运行 (毫秒
  • 和 浏览器多次尝试匹配 (高 匹配尝试 值) ,
  • 与匹配尝试值) 相比,浏览器实际上没有匹配许多元素,匹配计数值 (低,
  • 和 具有较高百分比的慢路径非匹配项。

例如,在上面的屏幕截图中:

  • 第一个 CSS 选择器 (.gallery .photo .meta ::selection) 最需要的时间。
  • 浏览器引擎尝试匹配此 CSS 选择器 6017 次,但仅匹配 3234 个元素。
  • 在不匹配的 2783 个元素中,78% 的元素需要较少的优化代码才能匹配。

因此,此 CSS 选择器非常适合尝试改进。

尝试更改 CSS 选择器,使其所需的计算时间更少,并且匹配页面上的元素更少。 如何改进 CSS 选择器取决于你的特定用例。 重复上述“记录”和“查看”部分中的步骤,以确认更改是否有助于缩短“已用 (ms) 列中的”重新计算样式“事件持续时间。

另请参阅