日期:2014-01-19 浏览次数:21193 次
CSS sprites 是网站速度的优化很重要的一环,但也有其对功用的不利之处。
Vladimir Vukićević 的博文《To Sprite Or Not To Sprite》提到:
CSS sprites 的最大问题是内存占用。非精确结构的 sprite 图片会占意图想不到的内存空间。以 WHIT TV 网站为例,这里是一张 sprite 图片,1299x15,000 的png,曾经经过很好的紧缩,实际下载大小只要26K左右,但是浏览器不会转换紧缩的图像数据。当图片下载并解压,将耗费75MB内存(1299 * 15000 * 4)。如果图片没有阿尔法通明,可能会减小到1299 * 15000 * 3,可往往还是牺牲了渲染速度。即便如此,我们占用了55MB内存。这张图片绝大部分是空白的,什么都没有,没有什么有用的内容。仅仅由于这张图片,当浏览器只加载WHIT 主页时会添加75+MB内存。
Mozilla Web Development Blog 在《 Use Sprites Wisely》中总结道:
简而言之,即便是很小的 sprite 图片也有可能吃掉大量的系统内存 -- 每个页面50M甚至100M或者更多。速度虽然至关重要,但要认识到 sprite 及其他 hacks 同样会影响用户体验。
如今再回过头看之前的《Yahoo与Gmail的CSS Sprites对比》,综合功用方面 Gmail 无疑占了上风。当然,这些只是前端层面的优化,从本源上来看,设计师用最少的图片来实现最优的效果才是王道。
正如雅虎女工程师 Nicole Sullivan 在 Velocity 2009 大会演讲 PPT 《The Fast And The Fabulous》所提到的:
consistent design = clean code = fast site(分歧的设计 = 更干净的代码 = 更快的网站)