雅虎前端优化14准则

雅虎前端优化14准则

1.尽可能使用少的HTTP请求MakefewerHTTPrequests; 

  这个是很重要的一条,具体措施是使用Imagemaps 和InlineImages;合并CSS和脚本代码。比如对于ImageMaps 
(服务器端)server-side 
→http://…/navbar.cgi?127,1

大家好,又见面了,我是你们的朋友全栈君。

1.尽可能使用少的HTTP请求 Make fewer HTTP requests; 

    这个是很重要的一条,具体措施是使用Image maps  和Inline Images;合并CSS和脚本代码。比如对于Image Maps 
(服务器端)server-side 
<a href=”navbar.cgi”> <img ismap src=”imagemap.gif”> </a>→ http://…/navbar.cgi?127,13 
(客户端)client-side – preferred 
<img usemap=”#map1″ border=0 src=”http://images.cnblogs.com/imagemap.gif”> 
<map name=”map1″>  <area shape=”rect” coords=”0,0,31,31″ href=”home.html” title=”Home”> 
  … 
</map> 
(缺点是)drawbacks: 
图片需要是连续的。 

2.使用内容分发网络 Use a CDN; 
  在发布你的动态内容之前发布网站的静态内容,比如使用广泛的Akamai 
3.增加一个期限头部 Add an Expires header 
  不仅仅是对图片设置,对于脚本和样式表同样需要设置,在Apache中具体的配置方法如下: 
    ExpiresActive On 
    ExpiresByType application/x-javascript “modification plus 2 years” 
    ExpiresByType text/css “modification plus 5 years” 
当你修改一个资源的时候,修改资源的名称(自动进行),给文件名称加一个时间戳,例如img_1385413733.png; 
同时候将资源纳入版本控制系统中,比如使用CVS个SVN,例如img_1.2.png。 

4.压缩组件Gzip components 
  当前90% 的浏览器都支持压缩,压缩不仅仅是指HTML,脚本,CSS和XML都可以压缩。 
在Apache中修改下面的配置来支持压缩 
Apache 2.x: mod_deflate 
AddOutputFilterByType DEFLATE text/html text/css application/x-javascript 
对于HTTP请求和响应,表现如下 
HTTP request: Accept-Encoding: gzip, deflate 
HTTP response: Content-Encoding: gzip Vary: Accept-Encoding 

5.将CSS置为页面的顶部 Put CSS at the top 
  主要原因是CSS样式表会阻塞HTML在IE中的显示(如果没有下载完的话)


6.将JS移植页面的底部 Move JS to the bottom 
  主要原因是脚本的执行会阻塞并行下载和阻塞其他元素在IE中的展示


7.避免使用CSS表达式 Avoid CSS expressions 

比如下面的例子: 

  width: expression( 

        document.body.clientWidth < 600 ? 

      “600px” : “auto” ); 

原因是由于鼠标的移动,按下键等操作事件会是的上述表达式执行多次  

8. 是JS和CSS从外部包含  Make JS and CSS external 

  可以减少HTML文档的大小,同时增加脚本的重用,但是会增加请求数 

但是HomePage是一个例外,在Homepage中使用Inline和 PostOnload效果不错,yahoo和goolgede 

首页都这样处理了; 

9.减少DNS的查找 Reduce DNS lookups 

  一个典型的DNS查询是20-120ms,DNS 查询的时间直接影响到并行下载的效率,尽量减少主机的域名数目。 

常用浏览器的缓存时间设置如下: 

IE 

DnsCacheTimeout: 30 minutes 

KeepAliveTimeout: 1 minute 

ServerInfoTimeout: 2 minutes 

Firefox 

network.dnsCacheExpiration: 1 minute 

network.dnsCacheEntries: 20 

network.http.keep-alive.timeout: 5 minutes 

Fasterfox: 1 hour, 512 entries, 30 seconds 

10.精简JS Minify JS 

  这个主要涉及到JS的编码和优化 

11.避免重定向 Avoid redirects 

  通常Web服务器返回的是3XX的状态码,常常是301和302,可以通过添加过期头来缓存重定向; 

12. 移除重复的脚本 Remove duplicate scripts 

    统计数剧表明20%的网站存在重复的脚本文件,这将直接影响HTTP请求的性能  

13.关闭ETags功能 Turn off ETags 

    Web服务器返回的实体的唯一标识,主要应用在有条件的Get请求中。 

    ETag: “c8897e-aee-4165acf0” 

    Last-Modified: Thu, 07 Oct 2004 20:54:08 GMT 

    If-None-Match: “c8897e-aee-4165acf0” 

  If-Modified-Since: Thu, 07 Oct 2004 20:54:08 GMT 

如果ETags不匹配,就不能发送304码,对于服务器之间一个单独的实体的ETag总是不同的。在Server和Client的格式分别 

如下: 

  Apache: inode-size-timestamp 

  IIS: Filetimestamp:ChangeNumber 

对于服务器多余一台机器的Site,很少返回304状态码。 

14.是AJAX代码可缓存同时经可能小 Make AJAX cacheable and small 

  XHR, JSON, iframe, 动态脚本 都是可以被缓存, 精简和压缩的:a personalized response should still be cacheable by that person。比如在Yahoo! Mail Beta中,由于XML标示的地址本是不会经常变动的,可以缓存它,将最后修改时间标记在URL中。 

Web性能分析工具 

1。IBM Page Detailer  详细信息参考:http://alphaworks.ibm.com/tech/pagedetailer 

2。Fasterfox 是Firefox的一个插件,可以详细统计一个网页的载入时间,http://fasterfox.mozdev.org/ 

3。LiveHTTPHeaders 是Firefox的一个插件,可以查看HTTP请求头  http://livehttpheaders.mozdev.org/ 

4。firebug 是Firefox的一个插件, 功能强大,可以多JS和CSS做分析 http://getfirebug.com/

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/159798.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • SPSS步骤|卡方检验详细操作和结果分析「建议收藏」

    SPSS步骤|卡方检验详细操作和结果分析「建议收藏」​卡方检验是很常用的一种分析方法,什么情况下使用卡方检验?如果你手上的数据是一种定类数据,比如性别(男、女)是否患病(是、否)。你还想要分析定类数据和定类数据之间的差异关系。例如想要分析性别和是否抽烟之间的关系。这一句话里面包含两个词语,分别是:性别,是否抽烟。性别为X,是否抽烟为Y。性别为定类数据,是否抽烟也是定类数据,此时就可以使用卡方检验。这篇文章分享分别使用两种常见统计分析工具SPSS和SPSSAU完成卡方检验。SPSS是目前常用的统计软件,SPSSAU是更简单的在线数据科学分析工具

    2022年5月17日
    119
  • 平凡的推送广告_朋友圈推送的广告怎么查找

    平凡的推送广告_朋友圈推送的广告怎么查找智能手机的广泛使用,使广告行业有了新一轮的冲击,并随之产生了新的广告模式之一——推送广告模式。什么是推送广告?    推送广告就是在通知栏显示出来的广告信息。这是一种新的移动广告业务,通过推送功能来实现营销目的,当然,APP开发者也通过它来获取了盈利。与传统的Banner广告条相比,推送广告可以与APP分离,既不占用屏幕内容,也不会对用户在体验APP过程中产生任何影响,因为它本身就

    2022年10月5日
    2
  • 结合Cookie的简单图片验证码的工作原理探究

    结合Cookie的简单图片验证码的工作原理探究在系统登录时,往往需要同时提交一个验证码。验证码的作用是验证登录者是不是人,因为人能轻松识别的图片,对于机器来说难度却比较大,因此在登陆时进行验证码校验可以阻断大部分爬虫机器人的骚扰,成本低,收益大,使得图片验证码得到了广泛的应用。本文通过网络分析的方式,stepbystep地探索了图片验证码的工作原理,文章技术门槛低,可读性和可操作性较强,适用于各种闲着没事干的无聊分子。1.百度“系统登录”,随便找了个登录网站:http://scm.fstvgo.com/2.打开该网站,按F12打开.

    2022年7月15日
    17
  • Java Integer最大值最小值输出

    Java Integer最大值最小值输出System.out.println(Integer.MAX_VALUE);System.out.println(Integer.MAX_VALUE+1);System.out.println(Integer.MIN_VALUE);System.out.println(Integer.MIN_VALUE-1);输出结果如下:2147483647-214748364

    2022年9月8日
    2
  • b站动漫_python爬b站视频

    b站动漫_python爬b站视频。。闲来无事,爬了一下我最爱的B站~~~卒首先进入B站的番剧索引页ps:以前经常浏览这个索引页找动漫看,所以熟练的操作~滑稽翻页发现url链接并没有改变,用谷歌开发者工具network发现加载了XHR文件并返回json格式的响应要对其进行翻页处理,观察一下querystring的规律,发现那么多个参数只有page这个参数是变化的所以接下来都很好做了~嘻嘻items.pyimp…

    2022年8月23日
    6
  • kettle教程二

    kettle教程二转载:http://www.cnblogs.com/limengqiang/archive/2013/01/16/KettleApply2.html1、应用场景这里简单概括一下几种具体的应用场景,按网络环境划分主要包括:表视图模式:这种情况我们经常遇到,就是在同一网络环境下,我们对各种数据源的表数据进行抽取、过滤、清洗等,例如历史数据同步、异构系统数据交互、数据对称发布或备份等都归属于这…

    2022年5月23日
    61

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号