首页 首页 >  文章资讯

Web程序优化的最佳实践

发布者:feixue2017    发布时间:2018-07-03 09:47:34    浏览次数:201次

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的对应关系,就像电话本中人名和他们的电话号码的 关系一样。当你在浏览器地址栏中输入www800hr时,DNS解析服务器就会返回这个 域名对应的IP地址。DNS解析的过程同样也是需要时间的。一般情况下返回给定域名对 应的IP地址会花费 20 到 120 毫秒的时间。而且在这个过程中浏览器什么都不会做直到 DNS查找完毕。


缓存 DNS 查找可以改善页面性能。这种缓存需要一个特定的缓存服务器,这种服务器一 般属于用户的 ISP 提供商或者本地局域网控制,但是它同样会在用户使用的计算机上产 生缓存。


DNS 信息会保留在操作系统的 DNS 缓存中(微软 Windows 系统中 DNS Client Service)。大多数浏览器有独立于操作系统以外的自己的缓存。由于浏览器有自己的 缓存记录,因此在一次请求中它不会受到操作系统的影响。


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


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


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


3、避免跳转


跳转是使用 301 和 302 代码实现的。

浏览器会把用户指向到 Location 中指定的 URL。头文件中的所有信息在一次跳转中都是 必需的,内容部分可以为空。不管他们的名称,301 和 302 响应都不会被缓存除非增加 一个额外的头选项,如 Expires 或者 Cache-Control 来指定它缓存。元素的刷 新标签和 JavaScript 也可以实现 URL 的跳转,但是如果你必须要跳转的时候,最好的


方法就是使用标准的 3XXHTTP 状态代码,这主要是为了确保"后退"按钮可以正确地使用。


但是要记住跳转会降低用户体验。在用户和 HTML 文档中间增加一个跳转,会拖延页面 中所有元素的显示,因为在 HTML 文件被加载前任何文件(图像、Flash 等)都不会被下 载。


天津博大医院

【版权与免责声明】如发现内容存在版权问题,烦请提供相关信息发邮件至 335760480@qq.com ,我们将及时沟通删除处理。 以上内容均为网友发布,转载仅代表网友个人观点,不代表平台观点,涉及言论、版权与本站无关。