Web前端性能优化

一、Web前端优化最佳实践之 内容 篇

1. 尽量减少HTTP请求;

合并文件,比如把多个css文件合成一个;
CSS Sprites 利用CSS background 相关元素进行背景图绝对定位;
图像地图 (在一个图像上划分不同区域映射不同的链接);
内联图像(使用data:URL scheme 在实际的页面嵌入图像数据);

2. 减少DNS查找:

DNS查询完成之前浏览器不能从这个主机下载任何任何文件。
方法:DNS缓存、将资源分布到恰当数量的主机名,平衡 并行下载和 DNS查询 ;

3. 避免重定向:多余的中间访问 (不是绝对的避免,尽量减少)

定义:重定向用于将用户从一个url重新路由到另一个url;
损伤:重定向的延迟也很严重,因为它延迟了整个html文档的传输,在html文档到达之前,页面中不会呈现出任何东西,也没有任何组件会被下载,在用户与html文档之间插入重定向延迟了页面中的所有东西;

4. 使Ajax可缓存

Ajax页面缓存是ajax处理数据时对一些重复相同数据进行一个缓存操作,这种设计使客户端对一些静态页面内容的请求,比如图片,css文件,js脚本等,变得更加快捷,提高了页面的响应速度,也节省了网络通信资源;

5. 非必须组件延迟加载 ,未来所需组件预加载 (异步);
6.减少DOM元素数量 ;
7. 切分组件到多个域;

主要的目的是提高页面组件并行下载能力,但不要跨太多域;

8. 最小化iframe的数量

iframes 提供了一个简单的方式把一个网站的内容嵌入到另一个网站中。 但我们需要慎重的使用iframe。iframe的创建比其它包括script和css的 DOM 元素的创建慢了 1-2 个数量级;
   使用 iframe 的页面一般不会包含太多 iframe,所以创建 DOM 节点所花费的时间不会占很大的比重。但带来一些其它的问题:onload 事件以及连接池(connection pool)。
** Iframes 阻塞页面加载**
  及时触发 window 的 onload 事件是非常重要的。onload 事件触发使浏览 器的 “忙” 指示器停止,告诉用户当前网页已经加载完毕。当 onload 事件 加载延迟后,它给用户的感觉就是这个网页非常慢。
  window 的 onload 事件需要在所有 iframe 加载完毕后(包含里面的元素)才会触发。在 Safari 和 Chrome 里,通过 JavaScript 动态设置 iframe 的src 可以避免这种阻塞情况。

9. 杜绝http 404错误;

二. Web前端优化最佳实践之 Server篇

  • 使用CDN ;
    内容分发网络(CDN)业务是指利用分布在不同区域的节点服务器群组成流量分配管理网络平台,为用户提供内容的分散存储和高速缓存,并根据网络动态流量和负载状况,将内容分发到快速、稳定的缓存服务器上,提高用户内容的访问响应速度和服务的可用性服务。
  • 添加Expires或者Cache-Control信息头 ;
  • Gzip压缩内容;

能有效减轻网络流量的压力;

  • 配置ETags(Entity Tag 实体标签);

属于HTTP协议的一部分,也就是所有的web服务器都应该(也确实能)支持这个特性。它的作用是用一个特殊的字符串来标识某个资源的“版本”,客户端(浏览器)来请求的时候,可以比较,如果ETag一致,则表示该资源并没有修改过,客户端(浏览器)可以使用自己缓存的版本;

  • 尽早刷新Buffer;
  • Ajax请求使用GET方法 ;

XMLHttpRequest POST要两步,而GET只需要一步(注意:在IE上GET能处理的最大url长度是2k);
几个需要补充的地方:
1、“当然,ETag对多数站点性能的影响并不是很大”,应该说ETag在正确使用的情况下,会让大量的请求以304头方式响应,可以相当的节省服务器资源和带宽。
2、对于尽早刷新这点,PHP几乎是做不到的,即使执行了flush以及类似的函数,也要等到请求完全执行之后,才会输出给浏览器端。
3、Ajax使用GET和POST各有好处,GET方式可以更快响应,但是可能会有被浏览器缓存的问题,一般都需要加个随机数来避免,POST方式则不会,so,最好是根据自己的情况分别使用GET和POST 方法;

  • 避免空src的img标签

三、Web前端优化最佳实践之 Cookie篇

  1. 缩小Cookie大小;尽量控制cookie的大小,不要塞入一些无用的信息;
  2. 针对Web组件使用域名无关性的Cookie;
    -- 这里说的Web组件,多指静态文件,比如图片、CSS等,客户端请求静态文件的时候,减少了Cookie的反复传输对主域名的影响;

四、Web前端优化最佳实践之 CSS篇

  • 把CSS放到代码页上端,浏览器能够有针对性的对HTML页面从上到下进行解析和渲染;
  • 避免CSS表达式 ;
  • 从页面中剥离JavaScript 与 CSS,能够有针对性的对其进行单独的处理策略,比如压缩或者缓存策略;
  • 精简JavaScript 与 CSS (语法能简写的简写);
  • 使用<link> 而不是@import (在IE中@import指令等同于把link标记写在HTML底部);
  • 避免使用Filter ;

五、Web前端优化最佳实践之 JavaScript篇

  1. 将脚本放到HTML代码页底部;
  2. 外部引入javascript和css;
  3. 压缩javascript和css ;
  4. 移除重复脚本 ;
  5. 减少DOM访问 ;

1、缓存已经访问过的元素;
2、“离线”更新节点,再将它们添加到树中;
3、避免使用JavaScript输出页面布局--应该是CSS的事儿;

  1. 合理设计事件监听器 ;

六、Web前端优化最佳实践之 Image 篇

  1. 优化图片:根据实际颜色需要选择色深、压缩 ;
  2. 优化css精灵 ;
  3. 不要在HTML中拉伸图片 ;
  4. 保证favicon.ico小并且可缓存 ;

七、Web前端优化最佳实践之 Mobile(iPhone) 篇

  • Web前端优化最佳实践最后一部分是针对移动应用的,其实只是针对iPhone的,目前只有两条规则;
  • 单个数据对象小于25k(Keep Components under 25k);
    --- Apple官方信息指出可缓存到内存中的Web数据对象最大支持到10M,但经过测试,发现也就是25k左右;
  • Pack Components into a Multipart Document
    --- 将Web页面组件打包成一个多部分组成的文档,其目的是减少HTTP请求。
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,864评论 6 494
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,175评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,401评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,170评论 1 286
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,276评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,364评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,401评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,179评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,604评论 1 306
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,902评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,070评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,751评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,380评论 3 319
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,077评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,312评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,924评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,957评论 2 351

推荐阅读更多精彩内容