如何优化JavaScript脚本的性能

作者:海啸 来源:海啸的地盘 时间:2008-02-19 21:47:00 

随着网络的发展,网速和机器速度的提高,越来越多的网站用到了丰富客户端技术。而现在Ajax则是最为流行的一种方式。JavaScript是一种解释型语言,所以能无法达到和C/Java之类的水平,限制了它能在客户端所做的事情,为了能改进他的性能,我想基于我以前给JavaScript做过的很多测试来谈谈自己的经验,希望能帮助大家改进自己的JavaScript脚本性能。

语言层次方面

循环

循环是很常用的一个控制结构,大部分东西要依靠它来完成,在JavaScript中,我们可以使用for(;;),while(),for(in)三种循环,事实上,这三种循环中for(in)的效率极差,因为他需要查询散列键,只要可以就应该尽量少用。for(;;)和while循环的性能应该说基本(平时使用时)等价。

而事实上,如何使用这两个循环,则有很大讲究。我在测试中有些很有意思的情况,见附录。最后得出的结论是:

如果是循环变量递增或递减,不要单独对循环变量赋值,应该在它最后一次读取的时候使用嵌套的++或—操作符。

如果要与数组的长度作比较,应该事先把数组的length属性放入一个局部变量中,减少查询次数。

局部变量和全局变量局部变量的速度要比全局变量的访问速度更快,因为全局变量其实是全局对象的成员,而局部变量是放在函数的栈当中的。

不使用Eval

使用eval相当于在运行时再次调用解释引擎对内容进行运行,需要消耗大量时间。这时候使用JavaScript所支持的闭包可以实现函数模版(关于闭包的内容请参考函数式编程的有关内容)

减少对象查找

因为JavaScript的解释性,所以a.b.c.d.e,需要进行至少4次查询操作,先检查a再检查a中的b,再检查b中的c,如此往下。所以如果这样的表达式重复出现,只要可能,应该尽量少出现这样的表达式,可以利用局部变量,把它放入一个临时的地方进行查询。

这一点可以和循环结合起来,因为我们常常要根据字符串、数组的长度进行循环,而通常这个长度是不变的,比如每次查询a.length,就要额外进行一个操作,而预先把var len=a.length,则就少了一次查询。

字符串连接

如果是追加字符串,最好使用s+=anotherStr操作,而不是要使用s=s+anotherStr。

如果要连接多个字符串,应该少使用+=,如s+=a;s+=b;s+=c;应该写成s+=a + b + c;而如果是收集字符串,比如多次对同一个字符串进行+=操作的话,最好使用一个缓存。怎么用呢?使用JavaScript数组来收集,最后使用join方法连接起来,如下

var buf = new Array();

for(var i = 0; i < 100; i++){ 
    buf.push(i.toString());
}

var all = buf.join("");

标签:JavaScript,优化,性能
0
投稿

猜你喜欢

  • 五步让你成为GO 语言高手

    2023-06-16 18:00:41
  • vue中使用vue-qriously插件生成二维码

    2024-04-27 16:01:31
  • JavaScript实现的一个计算数字步数的算法分享

    2024-05-03 15:32:42
  • Python如何实现FTP功能

    2021-10-22 15:08:25
  • pygame游戏之旅 调用按钮实现游戏开始功能

    2023-04-19 06:36:44
  • python判断字符串是否是json格式方法分享

    2023-01-02 20:50:37
  • MySQL数据库的一次死锁实例分析

    2024-01-27 18:21:58
  • python SVM 线性分类模型的实现

    2021-04-04 03:51:57
  • javascript实现数独解法

    2023-10-17 17:18:28
  • Python变量和字符串详解

    2023-08-23 02:59:49
  • 经典mysql连接查询例题

    2024-01-14 17:32:29
  • 数字人整合动网论坛的方法

    2009-05-29 18:23:00
  • python 实现简单的FTP程序

    2021-03-29 10:33:00
  • 趣味Python实战练习之自动更换桌面壁纸脚本附源码

    2021-11-03 09:12:33
  • python实现文本界面网络聊天室

    2022-04-13 19:43:54
  • Thinkphp5.0 框架使用模型Model添加、更新、删除数据操作详解

    2024-06-07 15:35:37
  • JS添加或删除HTML dom元素的方法实例分析

    2024-04-29 13:24:59
  • vue的常用组件操作方法应用分析

    2024-05-21 10:17:13
  • 解决Python安装后pip不能用的问题

    2023-05-10 04:52:14
  • Python+radar实现随机日期时间的生成

    2021-04-16 23:22:57
  • asp之家 网络编程 m.aspxhome.com