blog/_posts/2026-02-08-xslt.md
mayx 172882a99e Update 4 files
- /_posts/2026-02-08-xslt.md
- /_data/other_repo_list.csv
- /_tools/ai-summary.js
- /_tools/envs_post-receive
2026-02-08 12:35:47 +00:00

6.7 KiB
Raw Blame History

layout title tags
post 在Google杀死XSLT之后的XML美化方案
XML
Feed
XSLT
美化

即使没有了XSLT也不能让读者看到光秃秃的XML

起因

在半年前,我写了一篇用XSLT美化博客XML文件的文章自从那以后每次我在浏览其他人博客的时候都会看一眼对方博客有没有给自己的订阅文件做美化。不过就在前段时间我在浏览某个博客的时候发现他博客的订阅文件甚至连最基本的XML文档树都没有显示出来。这时候我打开开发者工具看了一眼源代码发现他也并没有使用xml-stylesheet之类的指令……而且控制台貌似报了些错好像是出现了什么CSP错误……于是我就想浏览器显示XML文档树的本质会不会其实也是一种XSLT之所以报错也有可能是浏览器在自动引用内置的XSLT时违反了CSP。所以我就问了问谷歌AI结果似乎真的是这样比如火狐浏览器就内置了一份XSLT文件IE浏览器也有。正当我为XSLT的功能感到强大时谷歌AI随后提到Chrome浏览器决定弃用XSLT所以以后不要再用XSLT了😰……
我给我的订阅文件加美化功能才半年怎么就要不能用了XSLT出现这么多年都还能用结果等我加上就要废弃了当时为了增加这个功能还是费了不少劲的怎么能让谷歌说没就没于是我就开始对这件事进行了调查。

Google杀死了XSLT

从上面Chrome的弃用XSLT文档中可以发现这件事的始作俑者是Mason Freed他在WHATWG中发起了一个Issue因为XSLT用的人很少以及实现XSLT的库很老而且容易出漏洞所以建议把XSLT从Web标准中删除。在这个Issue中可以发现有很多人表示不满毕竟这个功能对想要给自己订阅做美化的博主来说还是很有用的。为了对抗谷歌还有人做了个网站 https://xslt.rip
而且XSLT虽然用的人占比也许不高但从总量上应该还是挺多的除了用XSLT美化博客订阅的甚至还有用XSLT作为博客框架的,另外还有一些人提出一部分政府网站也有使用XSLT
不过Freed看起来对这件事早有准备他做了一个Polyfill库通过WASM的方式让XSLT可以正常工作为了方便大家使用这个库我顺手给CDNJS发了个PR以后可以用CDN引用它了。不过使用这个库的前提是需要在订阅中加一段引用JS的代码像我博客中的Atom订阅用的是jekyll-feed插件,里面的格式都是写死的,就用不了了……
只不过现在已经没办法阻止谷歌了……而且其他浏览器也表示会跟进,看来我们唯一能做的就是去适应了。

没有XSLT之后的美化方案

纯CSS

虽然XSLT不能用但不代表xml-stylesheet指令就不能用了除了XSLT之外xml-stylesheet同样可以引用CSS。只是似乎完全没见过用CSS美化订阅源的也许是因为光用CSS能做到的事比较少吧想用CSS给XML文档加链接之类的估计就做不到了。
但目前能选择的也不多了既然大家都没写过用CSS美化订阅源那就让我来写一个吧然而我并不会写😅……那就只好让AI来写了我把需求说清楚之后AI就写出来了feed.css。试了一下效果还挺不错的我让AI写的这个版本无论是RSS还是Atom都可以使用如果有人感兴趣可以拿去用。可惜我的Atom订阅因为用的是插件的原因用不了😭只能加到用纯Liquid实现的RSS订阅上了。
但用纯CSS的缺点也很明显没办法操作文档的内容像修改日期格式的就做不了了而且也不能添加超链接……XML的标签本身对浏览器来说并没有内建的语义正常情况下也没法让浏览器把某个标签当作超链接。那难道就没办法了吗

混合XHTML

如果完全不能修改XML内容那确实就没有办法了但如果能修改XML的内容那还是有办法的简单来说就是混入XHTML事实上Freed编写的Polyfill库原理上也是利用了XHTML只要在能作为XHTML的标签中添加XHTML的命名空间那么浏览器就可以理解它的语义并渲染像刚刚用纯CSS美化的订阅没有链接那就可以在根元素中添加命名空间xmlns:xhtml="http://www.w3.org/1999/xhtml",然后在合适的位置写:

<xhtml:a href="https://example.com">Read more -&gt;</xhtml:a>

就可以了。只是这样有个缺点,这样写的订阅文件不够“纯粹”,用验证器验证会显示“Misplaced XHTML content”警告。对有洁癖的人来说可能会有点难受😆
不过如果能接受这种“不纯粹”,那么其实xml-stylesheet指令也没必要了,link标签一样可以用,包括script也是,所以有人写了一个不使用XSLT美化XML的库。
只不过这种方法和XSLT相比还是有一些缺陷要知道XSLT的本质是转换是把XML转换为HTML也就是说转出来的文档本质是HTML所有的DOM操作都和操作HTML是完全相同的但是在XML里混入XHTML标签就不一样了它的本质依然是XML文档只是嵌入了XHTML命名空间下的元素所以相应的DOM操作会有一些不同。如果是自己写的纯JS可能还好如果是用了jQuery之类假定DOM为HTML的库就会出现问题了因此这也就是那个Polyfill库的局限性用正常的XSLT执行document.constructor会显示HTMLDocument而用这个Polyfill库执行完则是显示XMLDocument。因此直接套用为浏览器原生XSLT编写的旧样式文件就有可能会出问题但如果要考虑改XSLT的话那还不如重新写JS然后用XHTML引入呢。

感想

虽然有一些技术会因为各种各样的原因消失,但这不代表我们就要妥协一些东西,总有一些不同的技术可以解决相同的问题,所以我们只需要用其他的技术去实现就好了。不过这也是没办法的事情,毕竟没人能改变浏览器厂商们的决策啊😂