使用内联 CSS 样式缩小/优化/DRY 文档

问题描述

是否有一些库/工具/算法可以用内联 CSS 样式优化 HTML 文档。例如,对于给定的输入:

<div>
    <div>
        <span style="font-size:20px;">John</span>
        <span style="font-size:20px;">Doe</span>
    </div>
    <div>
        <span style="font-size:20px;">Frank</span>
        <span style="font-size:35px;">Westwood</span>
    </div>
    <div>
        <span style="font-size:20px;">Jane</span>
        <span style="font-size:25px;">River</span>
        Anonymous
    </div>
</div>

优化的输出应该是:

<div>
    <div style="font-size:20px;">
        <span>John</span>
        <span>Doe</span>
    </div>
    <div>
        <span style="font-size:20px;">Frank</span>
        <span style="font-size:35px;">Westwood</span>
    </div>
    <div>
        <span style="font-size:20px;">Jane</span>
        <span style="font-size:20px;">River</span>
        Anonymous
    </div>
</div>

可以优化带有 John Doe 跨度的第一个 div,并将相同的 20px 字体大小内联指令从跨度转移到父 div。但由于字体大小不匹配或未设置样式的文本节点(匿名),其他两个 div 无法优化。

我想象了一些通用算法,它遍历 DOM 树,从它的叶子开始,在每个级别上将内联 css 样式与所有兄弟姐妹进行比较,所有兄弟姐妹共有的片段从兄弟姐妹转移到他们的父母。

解决方法

暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!

如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。

小编邮箱:dio#foxmail.com (将#修改为@)

相关问答

错误1:Request method ‘DELETE‘ not supported 错误还原:...
错误1:启动docker镜像时报错:Error response from daemon:...
错误1:private field ‘xxx‘ is never assigned 按Alt...
报错如下,通过源不能下载,最后警告pip需升级版本 Requirem...