高性能网站建设指南-读书笔记

《高性能网站建设指南》读书笔记:

  性能黄金法则:

  只有10%~20%的最终用户响应时间花在了下载HTML文档上。其余的80%~90%时间花在了下载页面中的所有组件上。规则1 减少HTTP请求

  可以通过使用图片地图,CSS Sprites(有利有弊),内联图片(data:URL模式,IE不支持,不能被缓存),合并脚本和样式表。

  规则2 使用内容发布网络

  如果应用程序web服务器离用户更近,则一个HTTP请求的响应时间将缩短 ;

  如果组件web服务器离用户更近,则多个HTTP请求的响应时间将缩短。

  内容发布网络(CDN)是一组分布在多个不同地理位置的web服务器,用于更加有效地向用户发布内容。

  规则3 添加Expires头

  web服务器使用Expires头告诉web客户端他可以使用一个组件的当前副本,直到指定的时间为止。要求服务器与客户端的时钟严格同步,并且要在时间过期后在服务器配置中提供一个新的日期。

  Max-Age和mod_expires可以弥补Expires的不足。

  规则4 压缩组件

  从HTTp1.1开始,

  规则5 将样式表放在顶部

  逐步呈现,避免白屏

  规则6 将脚本放在底部

  HTTP1.1规范建议浏览器从每个主机名并行下载两个组件,在下载脚本时,并行下载实际上是被禁用的。

  原因之一是脚本有可能使用document.write来修改页面内容,因此浏览器会等待,以确保页面能够恰当地布局;

  原因之二是为了保证脚本能够按照正确的顺序执行,如果并行下载多个脚本,就无法保证响应是按照特定顺序到达浏览器。

  将脚本放在顶部将会阻塞对其后面内容的呈现,并且会阻塞对其后面组件的下载。

  规则7 避免CSS表达式

  表达式expression方法被其他浏览器忽略,但是对于IE来说是一个有用的工具。能够在IE中设置属性,创建跨浏览器的一致体验。例如,IE[IE6,IE7(Quirk),IE8(Quirk]不支持min-width属性,用表达式的方法可以解决这一问题:

  width: expression(document.body.clientwidth<600?"600px": "auto");

  min-width: 600px;

  表达式的问题在于对其进行的求值的频率比人们期望的要高。他们不仅在页面呈现和大小改变时求值,当页面滚动甚至用户鼠标在页面上移过时都要求值。我们可以向CSS表达式中添加一个计数器来进行跟踪。

  表达式计数器的实例:

  http://stevesouders.com/hpws/expression-counter.php

 {

  width: expression(setCntr(),document.body.clientwidth<600?"600px": "auto");

  min-width: 600px;

  }

  取代表达式的方法:事件处理器(Event Handlers)

  通过在onresize事件中设置样式的width属性来修正min-width问题。

  事件处理器的实例:

  http://stevesouders.com/hpws/event-handler.php

  当浏览器的大小改变时,这个例子使用setMinWidth()函数来修改所有段落元素的大小——

  10function setMinWidth(){

  setCntr(); //用于显示求值次数

  var aElements = document.getElementsByTagName("p");

  for(var i=0;i<aelements.length;i++){< p="">

  aElements[i].runtimeStyle.width=(document.body.clientwidth<600?"600px": "auto");

  }

  }

  if(1!=navigator.userAgent.indexOf("MSIE")){

  window.οnresize=setMinWidth;

  }

  这会在浏览器改变大小时中动态设置宽度,但是第一次呈现时这并不能恰当地设置段落大小,因此,页面还需要使用“一次性表达式”,通过表达式设置初始宽度。

  规则8 使用外部JavaScript和CSS

  规则9 减少DNS查找

  规则10 精简JavaScript

  精简VS混淆VS压缩

  规则11 避免重定向

  当Web服务器向浏览器返回一个重定向是,响应中就会拥有一个范围在3xx的状态码。这表示用户代理必须执行进一步操作才能完成请求。

  重定向影响的是HTML文档的下载。

  规则12 移除重复脚本

  规则13 配置ETag

  规则14 使Ajax可缓存

  最后奉上本书的内容提纲,以备复习使用!

高性能网站建设指南 

  扩展学习:

  HTTP/1.0和HTTP/2.0的区别

    www.rswebun.com

  http://blog.csdn.net/forgotaboutgirl/article/details/6936982

  http://www.php-oa.com/2008/10/28/httpnote.html

1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 、4下载使用后,可先查看README.md或论文文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 5、资源来自互联网采集,如有侵权,私聊博主删除。 6、可私信博主看论文后选择购买源代码。 1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合;、下载 4使用后,可先查看README.md或论文文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 5、资源来自互联网采集,如有侵权,私聊博主删除。 6、可私信博主看论文后选择购买源代码。 1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合;、 4下载使用后,可先查看README.md或论文文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 5、资源来自互联网采集,如有侵权,私聊博主删除。 6、可私信博主看论文后选择购买源代码。
1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看README.md或论文文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 5、资源来自互联网采集,如有侵权,私聊博主删除。 6、可私信博主看论文后选择购买源代码。 1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看README.m或d论文文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 5、资源来自互联网采集,如有侵权,私聊博主删除。 6、可私信博主看论文后选择购买源代码。 、1资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看README.md或论文文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 5、资源来自互联网采集,如有侵权,私聊博主删除。 6、可私信博主看论文后选择购买源代码。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值