我想critical-css
为React SSR
. 有很多方法可以实现这一点,但我对这种方法特别感兴趣——我计划在 react 渲染 html 后即时收集它。我在服务器上有 css,我想从中内联只需要的 css 并异步加载其余部分(我不确定性能,但我看到生产解决方案使用 purifyCSS 等工具执行此操作,所以我打算试一试并测量它表现)
问题 #1 - 关键 CSS 提取
我的 SSR 设置是基于renderToNodeStream而不是renderToString所以我不能这么容易地将 html 与 css 进行比较 - 块可能只是一段无效的 html 而没有结束标签。在这种情况下,如何有效地正确解析类名?我猜RegExp在这里可能会很慢?
问题 #2 - 将样式内联到 html 块中
我的计划是获取chunk of html
来自renderToNodeStream
并内联对应css
的响应 - 所以它的工作方式类似于interleaveWithStyles方法styled-components
这是块在styled-components
处理它后的样子——<style>
节点可能被插入到中间<svg>
——我想这不是问题,只要我最终会加载完整的 css,但这并不安全,因为这个节点可能很容易被删除,例如通过反应水合物。那么使用内联 css 丰富 html 流的正确方法是什么?