一、优化图片 几乎没有哪个网页上是没有图片的。如果你经历过56K猫的年代,你一定不会很喜欢有大量图片的网站。因为加载那样一个网页会花费大量的时间。 即使在现在,网络带宽有了很多的提高,56K猫逐渐淡出,优化图片以加快网页速度还是很有必要的。 优化图片包括减少图片数、降低图像质量、使用恰当的格式。 1、减少图片数:去除不必要的图片。 2、降低图像质量:如果不是很必要,尝试降低图像的质量,尤其是jpg格式,降低5%的质量看起来变化不是很大,但文大小的变化是比较大的。 3、常识使用脚本文件代替效果: 比如一些web2.0的样式,如果使用ps制作,每个图片基本会增加%5-%25的大小成本. 相反,使用javascript代码来实现效果,仅仅只增加几个字节.
0 c; N0 \. k) x( n' o1 D2 O二、图像格式的选择 一般在网页上使用的图片格式有三种,jpg、png、gif。三种格式的具体技术指标不是这篇文章探讨的内容,我们只需要知道在什么时候应该使用什么格式,以减少网页的加载时间。 1、JPG:一般用于展示风景、人物、艺术照的摄影作品。有时也用在电脑截屏上。 2、GIF:提供的颜色较少,可用在一些对颜色要求不高的地方,比如网站logo、按钮、表情等等。当然,gif的一个重要的应用是动画图片。 3、PNG:PNG格式能提供透明背景,是一种专为网页展示而发明的图片格式。一般用于需要背景透明显示或对图像质量要求较高的网页上。
" a6 L$ n- O/ y" k+ g: C三、优化CSS CSS叠层样式表让网页加载起来更高效,浏览体验也得到提高。有了CSS,表格布局的方式可以退休了。 但有时我们在写CSS的时候会使用了一些比较罗嗦的语句,比如这句: 7 t9 |. R7 J6 i' E0 I& u
复制内容到剪贴板 代码: margin-top: 10px; margin-right: 20px; margin-bottom: 10px; margin-left: 20px; 你可以将它简化为: margin: 10px 20px 10px 20px; 又或者这句: <p class="decorated">A paragraph of decorated text</p> <p class="decorated">Second paragraph</p> <p class="decorated">Third paragraph</p> <p class="decorated">Forth paragraph</p> 可以用div来包含: <div class="decorated"> <p>A paragraph of decorated text</p> <p>Second paragraph</p> <p>Third paragraph</p> <p>Forth paragraph</p> </div> 四、网址后加斜杠
+ p0 B( |2 g9 {* ^4 L' `有些网址,比如http://cheng-4.cn/512 当服务器收到这样一个地址请求的时候,它需要花费时间去确定这个地址的文件类型。如果220是一个目录,不妨在网址后多加一个斜杠,让其变成http://cheng-4.cn/512/,这样服务器就能一目了然地知道要访问该目录下的index或default文件,从而节省了加载时间。 & N" h o" A% }6 K4 e
五、标明高度和宽度
A& l% v& u# H( t# r, F这点很重要,但很多人由于懒惰或其它原因,总是将其忽视。当你在网页上添加图片或表格时,你应该指定它们的高度和宽度,也就是height和width参数。如果浏览器没有找到这两个参数,它需要一边下载图片一边计算大小,如果图片很多,浏览器需要不断地调整页面。这不但影响速度,也影响浏览体验。 9 z$ P" _6 c1 d! a4 [
下面是一个比较友好的图片代码: # [. J+ \4 K: c* _2 s
复制内容到剪贴板 代码: <img id="img" height="200" width="450" src="/Article/UploadFiles/200805/20080521125828444.gif" alt="banner" /> 当浏览器知道了高度和宽度参数后,即使图片暂时无法显示,页面上也会腾出图片的空位,然后继续加载后面的内容。从而加载时间快了,浏览体验也更好了 k i% ?$ f1 H3 Z4 R
六、减少http请求
0 L9 b' `, t- G |% U当浏览者打开某个网页,浏览器会发出很多对象请求(图像、脚本等等),视乎网络延时情况,每个对象加载都会有所延迟。如果网页上对象很多,这可以需要花费大量的时间。
; ^" R9 N* c' m1 K7 z1 k# d因此,要为http请求减负。如何减负?
% F! r4 N" N3 ]1、去除一些不必要的对象。
( r2 f; Q! m+ |. m4 q2 j, X) L, u, U2、将临近的两张图片合成一张。 ; M# r: Z# j, P" M
3、合并CSS文件 看看下面这段代码,需要加载三个CSS文件: <link rel="stylesheet" type="text/css" href="/body.css" /> <link rel="stylesheet" type="text/css" href="/side.css" /> <link rel="stylesheet" type="text/css" href="/footer.css" /> 我们可以将其合成一个: <link rel="stylesheet" type="text/css" href="/style.css" /> 从而减少http请求。
) a: \1 V' u9 b. C8 g2 d七、其它小技巧
5 K: k4 Z- l/ G1、去除不必要加载项。 2、如果在网页上嵌入了其它网站的widget,如果有选择余地,一定要选择速度快的。 3、尽量用图片代替flash,这对SEO也有好处。 4、有些内容可以静态化就将其静态化,以减少服务器的负担。 5、统计代码放在页尾(或者使用延迟加载)。 |