我一直在查看油脂猴子用户脚本的来源,并在他们的CSS中注意到以下内容:
.even { background: #fff url() repeat-x bottom}
我可以理解,滑脂脚本希望将其可以捆绑的所有内容捆绑在源代码中,而不是将其托管在服务器上,这很明显。但是由于我以前没有看过这种技术,因此我考虑了它的使用,并且由于许多原因,它似乎很有吸引力:
考虑到IE6(例如)在背景图片缓存方面存在问题,这似乎不是最糟糕的主意…
那么,这是好事还是坏事,为什么您不使用它,以及使用哪种工具对图像进行base64编码?
更新-测试结果
GZIP编码服务器端
发送给客户端的结果大小(YSLOW组件测试): 59.3Kb
发送到客户端浏览器的数据保存: 74.3Kb
不错,但是我猜它对较小的图像用处不大。
更新:Google的软件工程师Bryan McQuade在PageDevSummit 2013上表示,PageSpeed在ChromeDevSummit 2013上表示,CSS中的data:uris被认为是在演讲期间提供关键/最小CSS的渲染阻止反模式#perfmatters: Instant mobile webapps。
#perfmatters: Instant mobile webapps
如果要分别缓存图像和样式信息,这不是一个好主意。同样,如果您在css文件中编码大图像或大量图像,则浏览器将花费更长的时间下载文件,而无需任何样式信息即可离开网站,直到下载完成。对于小型图像,您不打算经常更改,这是一个很好的解决方案。