HTML关键CSS提取技巧【速查】
2026-04-28 16:18:49
0浏览
收藏
关键CSS提取是优化网页首屏加载性能的核心技术,其本质并非简单拆分所有样式,而是精准识别并内联首屏渲染真正必需的CSS规则,同时智能排除媒体查询、伪类、非首屏组件等干扰内容;文章对比了三种可靠落地方案:构建时首选基于真实DOM与CSSOM分析的critters(兼容Vite/Webpack但需注意@import限制)、服务端推荐精度更高但开销较大的penthouse(依赖无头浏览器与可访问URL)、静态HTML场景则可用cheerio配合启发式过滤;特别强调正则匹配因无法理解CSS语义、易受注释/换行/Unicode等影响而极不可靠,应坚决避免。

关键 CSS(Critical CSS)不是“把所有 CSS 拆出来”,而是提取首屏渲染必需的那部分样式规则,跳过媒体查询、伪类、@import、非首屏组件等无关内容。直接正则匹配或全文注入都容易出错——真正能落地的方案,取决于你用什么环境跑提取逻辑。
用 critters 在构建时提取(Vite / Webpack 场景)
critters 是目前最稳定的 Node.js 端提取器,它基于真实 DOM 渲染快照 + CSSOM 分析,不是纯字符串解析。它能自动忽略 @media (min-width: 768px)、:hover、.sidebar(若不在首屏 DOM 中)等规则。
- Webpack 用户:配
CrittersPlugin,传入html入口路径和publicPath,插件会自动注入到 - Vite 用户:用
vite-plugin-critters,注意需开启build.ssr或预渲染 HTML(否则无 DOM 快照可分析) - ⚠️ 坑点:
critters不处理内联中的@import;若 CSS 里写了@import 'base.css',它不会去加载并解析那个文件
用 penthouse 做服务端提取(Node.js 运行时)
penthouse 本质是启动一个无头浏览器(Puppeteer),打开页面、截取首屏 DOM、再反向推导哪些 CSS 规则被实际用到。它比 critters 更准,但慢、内存高,适合 CI/CD 阶段做一次生成,不适合请求时动态跑。
- 必须提供可访问的 URL(如
http://localhost:3000/home),不能只给 HTML 字符串 - 超时默认 30s,复杂 SPA 建议设
timeout: 60000,否则常因 JS 加载未完成而漏提 - 输出是纯 CSS 字符串,不含
标签,要自己拼进 HTML —— 别漏了type="text/css"
用 cheerio + 手动规则过滤(纯 HTML 字符串场景)
如果你只有静态 HTML 字符串(比如 CMS 输出、邮件模板),没服务端渲染能力,又不想引入 Puppeteer,那就得退回到“启发式提取”:先用 cheerio 解析 DOM,再按规则筛选 和 ,最后靠白名单控制范围。
- 只加载
href路径含/css/critical.或media="print"的除外(那是非关键) - 跳过所有含
@media、@supports、:not(、::before的规则行(用postcss解析 AST 更稳,但重) cheerio.load(html).$('link[rel="stylesheet"][href*="critical"]').attr('href')只拿链接,不下载内容 —— 下载动作得你自己用fetch或axios补上
为什么不用正则从 HTML 字符串里直接抽 CSS 内容?
因为

