前端工程与性能优化

前端工程与性能优化

ID:9003771

大小:418.89 KB

页数:20页

时间:2018-04-14

前端工程与性能优化_第1页
前端工程与性能优化_第2页
前端工程与性能优化_第3页
前端工程与性能优化_第4页
前端工程与性能优化_第5页
资源描述:

《前端工程与性能优化》由会员上传分享,免费在线阅读,更多相关内容在应用文档-天天文库

1、前端工程与性能优化  每个参与过开发企业级web应用的前端工程师或许都曾思考过前端性能优化方面的问题。我们有雅虎14条性能优化原则,还有两本很经典的性能优化指导书:《高性能网站建设指南》、《高性能网站建设进阶指南》。经验丰富的工程师对于前端性能优化方法耳濡目染,基本都能一一列举出来。这些性能优化原则大概是在7年前提出的,对于web性能优化至今都有非常重要的指导意义。  然而,对于构建大型web应用的团队来说,要坚持贯彻这些优化原则并不是一件十分容易的事。因为优化原则中很多要求与工程管理相违背,比如“把cs

2、s放在头部”和“把js放在尾部”这两条原则,我们不能让整个团队的工程师在写样式和脚本引用的时候都去修改同一份的页面文件。这会严重影响团队成员间并行开发的效率,尤其是在团队有版本管理的情况下,每天要花大量的时间进行代码修改合并,这项成本是难以接受的。因此在前端工程界,总会看到周期性的性能优化工作,辛勤的前端工程师们每到月圆之夜就会倾巢出动根据优化原则做一次最佳实践。  本文从一个全新的视角来思考web性能优化与前端工程之间的关系,通过解读百度前端集成解决方案小组(F.I.S)在打造高性能前端架构并统一百度4

3、0多条前端产品线的过程中所经历的技术尝试,揭示前端性能优化在前端架构及开发工具设计层面的实现思路。  性能优化原则及分类  笔者先假设本文的读者是有前端开发经验的工程师,并对企业级web应用开发及性能优化有一定的思考。因此我不会重复介绍雅虎14条性能优化原则,如果您没有这些前续知识的,请移步这里来学习。  首先,我们把雅虎14条优化原则,《高性能网站建设指南》以及《高性能网站建设进阶指南》中提到的优化点做一次梳理,如果按照优化方向分类可以得到这样一张表格:  优化方向优化手段请求数量合并脚本和样式表,CS

4、SSprites,拆分初始化负载,划分主域请求带宽开启GZip,精简JavaScript,移除重复脚本,图像优化缓存使用CDN,使用外部JavaScript和CSS,添加Expires头,减少DNS利用查找,配置ETag,使AjaX可缓存页面结构将样式表放在顶部,将脚本放在底部,尽早刷新文档的输出代码校验避免CSS表达式,避免重定向  目前大多数前端团队可以利用yuicompressor或者googleclosurecompiler等压缩工具很容易做到“精简javascript”这条原则,同样的,也可以使

5、用图片压缩工具对图像进行压缩,实现“图像优化”原则,这两条原则是对单个资源的处理,因此不会引起任何工程方面的问题;很多团队也通过引入代码校验流程来确保实现“避免css表达式”和“避免重定向”原则;目前绝大多数互联网公司也已经开启了服务端的Gzip压缩,并使用CDN实现静态资源的缓存和快速访问;一些技术实力雄厚的前端团队甚至研发出了自动CSSSprites工具,解决了CSSSprites在工程维护方面的难题。使用“查找-替换”思路,我们似乎也可以很好的实现“划分主域”原则。  我们把以上这些已经成熟应用到实

6、际生产中的优化手段去除掉,留下那些还没有很好实现的优化原则,再来回顾一下之前的性能优化分类:  优化方向优化手段请求数量合并脚本和样式表,拆分初始化负载请求带宽移除重复脚本缓存利用添加Expires头,配置ETag,使Ajax可缓存页面结构将样式表放在顶部,将脚本放在底部,尽早刷新文档的输出  诚然,不可否认现在有很多顶尖的前端团队可以将上述还剩下的优化原则也都一一解决,但业界大多数团队都还没能很好的解决这些问题,因此接下来本文将就这些原则的解决方案做进一步的分析与讲解,从而为那些还没有进入前端工业化开发

7、的团队提供一些基础技术建设意见,也借此机会与业界顶尖的前端团队在工业化工程化方向上交流一下彼此的心得。  静态资源版本更新与缓存  如表格2所示,在“缓存利用”分类中保留了“添加Expires头”和“配置ETag”两项,或许有些人会质疑,明明这两项只要配置了服务器的相关选项就可以实现,为什么说它们难以解决呢?确实,开启这两项很容易,但开启了缓存后,我们的项目就开始面临另一个挑战:如何更新这些缓存。  相信大多数团队也找到了类似的答案,它和《高性能网站建设指南》关于“添加Expires头”所说的原则一样——

8、修订文件名。即:  思路没错,但要怎么改变链接呢?变成什么样的链接才能有效更新缓存,又能最大限度避免那些没有修改过的文件缓存不失效呢?  先来看看现在一般前端团队的做法:  或者  大家会采用添加

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。