Javascript高性能编程总结

1 篇文章 0 订阅
1 篇文章 0 订阅

Javascript高性能编程

  1. 访问字面量和局部变量的速度更快,访问数组元素和对象成员相对较慢。

  2. 由于局部变量存在于作用域链的起始问自己,因此访问局部变量比访问跨作用域变量更快。变量在作用域中的位置越深,访问所需时间久越长。由于全局变量总处在作用域链的最末端,因此访问速度也是最慢的。

  3. 嵌套的对象成员会明显影响性能,尽量少用。

  4. 属性和方法在原型链中的位置越深,访问速度就越慢。

  5. 通常来说,可以通过把常用的对象成员、数组元素、跨域变量保存在局部变量中来改善javascript性能,因为局部变量访问速度越快。

 

 

  1. 最小化DOM访问次数,尽可能在javascript端处理。

  2. 如果需要多次访问莫个DOM节点,使用局部变量存储它的引用。

  3. 小心处理HTML集合,因为它实时联系着底层文档。把集合的长度缓存到一个变量中,并在迭代中使用它。如果需要经常操作集合,建议把它拷贝到一个数组中。

  4. 如果可能的话,使用熟读更快的API,比如querySelectorAll()和firstElementChild。

  5. 要留意重绘和重排,批量修改样式时,“离线”操作DOM树,使用缓存,并减少访问布局信息的次数。

  6. 动画中使用绝对定位,使用拖放代理。

  7. 使用事件委托来减少事件处理器的数量。

  8. 改善循环性能的最佳方式是减少每次迭代的运算量和减少循坏迭代次数。

  9. 通常来说,switch总是比if-else快,但并不总是最佳解决方案。

  10. 在端盘条件较多时,使用查找表比if-else和switch更快。

  11. 浏览器的调用栈大小限制了递归算法在javasc中的应用;栈溢出错误会导致其他代码中断运行。

  12. 如果遇到栈溢出错误,可讲方法改为迭代算法,或使用memoiaztion来避免重复计算。

 

  1. for、while和do-while循环性能相当,并没有一种循坏类型明显快于或慢于其他类型。

  2. 避免使用for-in循环,除非你需要遍历一个属性数量未知的对象。

 

  1. 回溯既是正则表达式匹配功能的基本组成部分,也是正则表达式的低效之源。

 

  1. 任何javascript任务都不应当执行超过100毫秒。js的运行时间会导致UI更新出现明显的延迟,从而对用户体验产生负面影响。

  2. js运行期间,浏览器响应用户交互的行为存在差异。无论如何,js长时间运行将导致用户体验变得混乱和脱节。

  3. 定时器可用来安排代码延迟执行。

  4. web worker是新版浏览器支持的特性,它允许你在UI线程外部执行javascript代码,从而避免锁定UI。

 

 

  1. 减少请求数,合并js和css文件。

  2. 缩短页面的加载时间,页面主要内容加载完成后,才用ajax获取那些次要的文件。

  3. 压缩js文件。

  4. 在服务器端压缩js文件(gzip)。

  5. 通过正确设置HTTP响应头来缓存js文件。

  6. 使用cdn提供js文件。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值