JavaScript项目优化总结项目优化总结
前端时间对公司已有项目JavaScript代码进行优化,本文的是对优化工作的一个总结,拿出来与大家分享。当然我的优化方式
可能并不是最优的,或者说有些不对的地方,请指教。
JavaScript优化总结分为以下几点
优化前后对比
优化前 优化后
代码混乱,同样功能的函数重复出现在多个
地方。如果需要修改实现,需要找到所有的
地方。牵一发而动全身
模块化,提取公共接口组织为
库、结构清晰、方便代码重用、
并且能够游戏防止变量污染问
题。
JavaScript文件未压缩,size比较大加载消耗
网络耗时,阻塞页面渲染
JavaScript公共库文件使用
UglifyJS压缩:
?Size比较小优化了网络加
载时
压缩混淆了代码,在一定程
度上保护代码
使用时需要加载多个单独的JavaScript文
件,增加了http请求数降低性能
对公共库合并压缩在减少size的
同时,减少http请求数
缺乏文档(让后面的开发者对已有功能不清
楚,这在一定程度上造成前面说的,同样功
能的函数重复出现在多个地方)
公共库中每个类、函数、属性都
有说明文档
代码混乱,同样功能的函数重复出现在多个地方。如果需要修改实现,需要找到所有的地方。牵一发而动全身
模块化,提取公共接口组织为库、结构清晰、方便代码重用、并且能够游戏防止变量污染问题
JavaScript文件未压缩,size比较大加载消耗网络耗时,阻塞页面渲染
JavaScript公共库文件使用UglifyJS压缩:
Size比较小优化了网络加载时间
压缩混淆了代码,在一定程度上保护代码
使用时需要加载多个单独的JavaScript文件,增加了http请求数降低性能
对公共库合并压缩在减少size的同时,减少http请求数
缺乏文档(让后面的开发者对已有功能不清楚,这在一定程度上造成前面说的,同样功能的函数重复出现在多个地方)
公共库中每个类、函数、属性都有说明文档
模块化(类编程):代码清晰、有效防止变量污染问题、代码重用方便扩展等;
JavaScript压缩混淆:减少size优化加载时间,混淆保护代码;
JavaScript文件合并:减少http请求优化网络耗时提升性能;
生成文档:方便公共库的使用,查找接口方便。
模块化(类编程)
对于静态类来说JavaScript实现比较简单,使用Object直接量就已经够用了;但是要创建实例化、可继承经典的类需要做一番
工作。因为JavaScript是基于原型的(prototype-based)编程语言,并没有包含内置类的实现(它没有访问控制符,它没有定
义类的关键字class,它没有支持继承的extend或冒号,它也没有用来支持虚函数的virtual等),但是我们通过JavaScript可以
轻易地模拟出经典的类。
静态类
根据宝宝JS公共接口的特性,它们不需要实例化,所以优化使用了该方式。下面以PetConfigParser为例介绍下实现方式: