图片优化技巧:前端开发中的图片优化

2013-10-29 20:35:39  来历:博客园 

网页制造Webjx文章简介:本文关于图片优化的内容首要由两部分构成:1. 收拾总结网上关于图片优化的一些办法办法。2. 自己在项目开发过程中实践遇到的问题以及用到的图片优化计划。

现在的互联网,是一个用户体会至上的年代,大多数公司都会把怎么进步产品的易用性放在首要方位。怎么进步产品的质量则表现在项目开发的许多阶段,例如产品规划、UI规划和前端开发等。而图片优化在进步产品质量上也起到了无足轻重的作用,这也便是为什么越来越多的产品团队愈加重视这个问题。

本文关于图片优化的内容首要由两部分构成:

1. 收拾总结网上关于图片优化的一些办法办法。

2. 自己在项目开发过程中实践遇到的问题以及用到的图片优化计划。

如有不足之处,欢迎咱们指出并弥补。

1. 精约而不简单

Win8和iOS7的呈现,将互联网职业中许多产品规划带回到原点,或许更是另一个新的起点。Win8的Metro UI、iOS7中图标的扁平化规划、一向崇尚精约的豆瓣网、还有顶着年代工匠称谓的老罗所规划的锤子ROM,无一不表现着精约的风格。

言归正传,回到咱们图片优化的主题上。在产品规划和UI规划阶段,除了内容图片,其他的图片都是起润饰的作用。也便是关于传递信息来说并非实质性的。所以最大的优化便是不要图片。在进入到研制阶段之前,就要承认规划,规划自身是否需求用到那么多的图片,仍是说能够做到更简练!

2. 款式替代图片

Chrome,FF等阅览器厂商为互联网的开展做了这么多奉献,为什么咱们还要让那些不兼容CSS3的阅览器阻止互联网的开展呢。因而,让咱们直接运用CSS款式替代图片来完结润饰作用!例如:半通明、圆角、暗影、高光、突变等。这些作用干流的阅览器都能够完美支撑,而关于那些低端阅览器,咱们并不会彻底扔掉他们,“渐进增强”则是一个很好的解决计划。至于什么是渐进增强,这儿不再用过多篇幅去解说,假如感兴趣能够参阅CSS“渐进增强”在web制造中常见运用举例。

3. 挑选最适宜的图片

咱们常见的图片格局有JPEG、GIF、PNG。

基本上,内容图片多为相片之类或图片构成较杂乱的状况,适用于JPEG。如网站中的Banner图、轮播图、大尺度布景图等。

润饰图片一般更适合用无损紧缩的PNG。而咱们首要用到的PNG图片又分为PNG-8和PNG-24两种,PNG-8格局不支撑半通明,也是IE6兼容的图片存储办法。假如对图片质量要求较高的半通明或全通明布景,保存成PNG-24更适宜。有时候会遇到在IE6下运用PNG-24图片的状况,关于IE6下PNG Alpha通明的解决计划能够参阅IE6中PNG Alpha通明。我在项目中常用的办法是AlphaImageLoader挑选器。

GIF基本上除了GIF动画外不要运用。

除了这些格局之外,Chrome、新版Opera、Android 4+支撑WebP格局,IE 9+、IE mobile 10+支撑JPEG XR。这两个新格局都支撑无损和有损紧缩,都具有更杰出的紧缩比。当然这需求为不同的阅览器回来不同的图片,添加了开发本钱,也添加存储本钱。不过你省了流量或许相同流量下改进了图片质量,进步了用户体会。这就需求依据项目需求进行取舍了。

4. 常用的图片优化技巧

CSS Sprites,将同类型的图标或按钮等布景图合到一张大图中,削减页面恳求。

Icon Font,将图标做成字体文件。长处是图标支撑多个尺度,兼容一切阅览器,削减页面恳求等。美中不足的是只支撑纯色的icon。

SVG,关于绝大多数图画、图标等,矢量图更小,且可缩放而无需生成多套图。现在干流阅览器都支撑SVG了,所以可放心运用!

图片紧缩东西,能够在图片上线前运用紧缩东西进行紧缩,取得更高的紧缩比。我常用的紧缩东西为Yahoo的Smush.it。 

5. 适用各种资源而不限于图片的优化

data url

Base64是网络上最常见的用于传输8Bit字节的编码办法之一,可用于在HTTP环境下传递较长的标明信息。将图片转化为base64编码格局,资源内嵌于CSS或HTML中,不用独自恳求。

该办法的长处是:

1. 削减了HTTP恳求

2. 避免了图片从头上传,还要整理缓存的问题 

不足之处是:

1. IE6, IE7不支撑该类型编码的图片作为布景图

2. 添加了CSS文件的尺度

3. 保护本钱较高

依照HTTP协议设置合理的缓存

详细的缓存战略(如永久缓存 + 重命名)、布置战略(如反向署理、CDN等)这儿就不打开了。

Responsive规划

为了习惯现在很多分辨率和设备像素比的移动设备,要发生多套不同巨细和分辨率的图片,然后合作Media Query进行开发。这儿引荐在进行移动端页面开发时运用SVG或Icon Font等技能。这些技能能够完美支撑Retina设备。关于更多呼应式计划,能够参阅《呼应式Web规划: HTML5和CSS3实践》这本书或网上相关材料,这儿不再打开。

以上为项目中常用的图片优化技能,只要更多地重视细节,才干做出优异的产品。今后会介绍更多文章中呈现的技能细节。

更多