日期:2013-10-20  浏览次数:20812 次

英文地址:http://developer.yahoo.com/performance/rules.html

Yahoo!的Exceptional Performance团队为改善Web功用带来最佳实践。他们为此进行了一系列的实验、开发了各种工具、写了大量的文章和博客并在各种会议上参与探讨。最佳实践的核心就是旨在提高网站功用。

Excetional Performance团队总结出了一系列可以提高网站速度的方法。可以分为7大类34条。包括内容、服务器、cookie、CSS、JavaScript、图片、挪动使用等七部分。

其中内容部分一共十条建议:

一、内容部分

  1. 尽量减少HTTP请求
  2. 减少DNS查找
  3. 避免跳转
  4. 缓存Ajxa
  5. 推迟加载
  6. 提前加载
  7. 减少DOM元素数量
  8. 用域名划分页面内容
  9. 减小iframe的大小
  10. 避免404错误

1、尽量减少HTTP请求次数

终端用户呼应的时间中,有80%用于下载各项内容。这部分时间包括下载页面中的图像、款式表、脚本、Flash等。通过减少页面中的元素可以减少HTTP请求的次数。这是提高网页速度的关键步骤。

减少页面组件的方法其实就是简化页面设计。那么有没有一种方法既能保持页面内容的丰富性又能达到加快呼应时间的目的呢?这里有几条减少HTTP请求次数同时又可能保持页面内容丰富的技术。

合并文件是通过把所有的脚本放到一个文件中来减少HTTP请求的方法,如可以简单地把所有的CSS文件都放入一个款式表中。当脚本或者款式表在不同页面中使用时需求做不同的修正,这可能会绝对麻烦点,但即便如此也要把这个方法作为改善页面功用的重要一步。

CSS Sprites 是减少图像请求的无效方法。把所有的背景图像都放到一个图片文件中,然后通过CSS的background-image和background-position属性来显示图片的不同部分;

图片地图是把多张图片整合到一张图片中。虽然文件的总体大小不会改变,但是可以减少HTTP请求次数。图片地图只要在图片的所有组成部分在页面中是紧挨在一同的时候才能使用,如导航栏。确定图片的坐标和可能会比较繁琐且容易出错,同时使用图片地图导航也不具有可读性,因此不推荐这种方法;

内联图像是使用 data:URL scheme 的方法把图像数据加载页面中。这可能会添加页面的大小。把内联图像放到款式表(可缓存)中可以减少HTTP请求同时又避免添加页面文件的大小。但是内联图像如今还没有得到主流浏览器的支持。点击这里查看网页制造教程频道内容

减少页面的HTTP请求次数是你首先要做的一步。这是改进初次访问用户等待时间的最重要的方法。好像Tenni Theurer的他的博客Browser Cahe Usage - Exposed!中所说,HTTP请求在无缓存情况下占去了40%到60%的呼应时间。让那些初次访问你网站的人获得愈加快速的体验吧!

2、减少DNS查找次数

域名系统(DNS)提供了域名和IP的对应关系,就像电话本中人名和他们的电话号码的关系一样。当你在浏览器地址栏中输入www.dudo.org时,DNS解析服务器就会前往这个域名对应的IP地址。DNS解析的过程同样也是需求时间的。普通情况下前往给定域名对应的IP地址会花费20到120毫秒的时间。而且在这个过程中浏览器什么都不会做直到DNS查找完毕。

缓存DNS查找可以改善页面功用。这种缓存需求一个特定的缓存服务器,这种服务器普通属于用户的ISP提供商或者本地局域网控制,但是它同样会在用户使用的计算机上产生缓存。DNS信息会保留在操作系统的DNS缓存中(微软Windows系统中DNS Client Service)。大多数浏览器有独立于操作系统以外的本人的缓存。由于浏览器有本人的缓存记录,因此在一次请求中它不会遭到操作系统的影响。点击这里查看网页制造教程频道内容

Internet Explorer默认情况下对DNS查找记录的缓存时间为30分钟,它在注册表中的键值为DnsCacheTimeout。Firefox对DNS的查找记录缓存时间为1分钟,它在配置文件中的选项为network.dnsCacheExpiration(Fasterfox把这个选项改为了1小时)。

当客户端中的DNS缓存都为空时(浏览器和操作系统都为空),DNS查找的次数和页面中主机名的数量相反。这其中包括页面中URL、图片、脚本文件、款式表、Flash对象等包含的主机名。减少主机名的数量可以减少DNS查找次数。

减少主机名的数量还可以减少页面中并行下载的数量。减少DNS查找次数可以节省呼应时间,但是减少并行下载却会添加呼应时间。我的指点准绳是把这些页面中的内容分割成至少两部分但不超过四部分。这种结果就是在减少DNS查找次数和保持较高程度并行下载两者之间的权衡了。