我的编程空间,编程开发者的网络收藏夹
学习永远不晚

如何提高JavaScript执行效率

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

如何提高JavaScript执行效率

这篇文章将为大家详细讲解有关如何提高JavaScript执行效率,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。

文中所提供的代码片段都已经过最新版的Chrome 30测试,该浏览器使用V8 JavaScript引擎(V8 3.20.17.15)。

1.使用逻辑符号&&或者||进行条件判断

var foo = 10; 
foo == 10 && doSomething(); // 如果 foo == 10 则执行 doSomething(); 
foo == 5 || doSomething(); // 如果 foo != 5 则执行doSomething();

“||”也可以用来设置函数参数的默认值

Function doSomething(arg1){ 
 Arg1 = arg1 || 10; // 如果 arg1为设置那么 Arg1=10
}

2.使用map()方法来遍历数组

var squares = [1,2,3,4].map(function (val) { 
 return val * val; 
}); 
// 运行结果为 [1, 4, 9, 16]

3.舍入小数位数

var num =2.443242342; 
num = num.toFixed(4); // 保留四位小数位 2.4432

4.浮点数问题

0.1 + 0.2 === 0.3 // is false 
9007199254740992 + 1 // = 9007199254740992 
9007199254740992 + 2 // = 9007199254740994

0.1+0.2等于0.30000000000000004,为什么会发生这种情况?根据IEEE754标准,你需要知道的是所有JavaScript数字在64位二进制内的都表示浮点数。开发者可以使用toFixed()和toPrecision()方法来解决这个问题。

5.使用for-in loop检查遍历对象属性

下面这段代码主要是为了避免遍历对象属性。

for (var name in object) { 
 if (object.hasOwnProperty(name)) { 
  // 执行代码
 } 
}

6.逗号操作符

var a = 0; 
var b = ( a++, 99 ); 
console.log(a); // a 为 1 
console.log(b); // b 为 99

7.计算或查询缓存变量

在使用jQuery选择器的情况下,开发者可以缓存DOM元素

var navright = document.querySelector('#right'); 
var navleft = document.querySelector('#left'); 
var navup = document.querySelector('#up'); 
var navdown = document.querySelector('#down');

8.在将参数传递到isFinite()之前进行验证

isFinite(0/0) ; // false 
isFinite("foo"); // false 
isFinite("10"); // true 
isFinite(10); // true 
isFinite(undifined); // false 
isFinite(); // false 
isFinite(null); // true !!!

9.在数组中避免负向索引

var numbersArray = [1,2,3,4,5]; 
var from = numbersArray.indexOf("foo") ; // from is equal to -1 
numbersArray.splice(from,2); // will return [5]

确保参数传递到indexOf()方法里是非负向的。

10.(使用JSON)序列化和反序列化

var person = {name :'Saad', age : 26, department : {ID : 15, name : "R&D"} }; 
var stringFromPerson = JSON.stringify(person); 
 
var personFromString = JSON.parse(stringFromPerson); 

11.避免使用eval()或Function构造函数

eval()和Function构造函数被称为脚本引擎,每次执行它们的时候都必须把源码转换成可执行的代码,这是非常昂贵的操作。

var func1 = new Function(functionCode); 
var func2 = eval(functionCode);

12.避免使用with()方法

如果在全局区域里使用with()插入变量,那么,万一有一个变量名字和它名字一样,就很容易混淆和重写。

13.避免在数组里使用for-in loop

而不是这样用:

var sum = 0; 
for (var i in arrayNumbers) { 
 sum += arrayNumbers[i]; 
}

这样会更好:

var sum = 0; 
for (var i = 0, len = arrayNumbers.length; i < len; i++) { 
 sum += arrayNumbers[i]; 
}

因为i和len是循环中的第一个语句,所以每次实例化都会执行一次,这样执行起来就会比下面这个更快:

for (var i = 0; i < arrayNumbers.length; i++)

为什么?数组长度arraynNumbers在每次loop迭代时都会被重新计算。

14.不要向setTimeout()和setInterval()方法里传递字符串

如果在这两个方法里传递字符串,那么字符串会像eval那样重新计算,这样速度就会变慢,而不是这样使用:

setInterval('doSomethingPeriodically()', 1000); 
setTimeOut('doSomethingAfterFiveSeconds()', 5000);

相反,应该这样用:

setInterval(doSomethingPeriodically, 1000); 
setTimeOut(doSomethingAfterFiveSeconds, 5000);

15.使用switch/case语句代替较长的if/else语句

如果有超过2个以上的case,那么使用switch/case速度会快很多,而且代码看起来更加优雅。

16.遇到数值范围时,可以选用switch/casne

function getCategory(age) { 
 var category = ""; 
 switch (true) { 
  case isNaN(age): 
   category = "not an age"; 
   break; 
  case (age >= 50): 
   category = "Old"; 
   break; 
  case (age <= 20): 
   category = "Baby"; 
   break; 
  default: 
   category = "Young"; 
   break; 
 }; 
 return category; 
} 
getCategory(5); // 返回 "Baby"

17.创建一个对象,该对象的属性是一个给定的对象

可以编写一个这样的函数,创建一个对象,该对象属性是一个给定的对象,好比这样:

function clone(object) { 
 function OneShotConstructor(){}; 
 OneShotConstructor.prototype= object; 
 return new OneShotConstructor(); 
} 
clone(Array).prototype ; // []

18.一个HTML escaper函数

function escapeHTML(text) { 
 var replacements= {"<": "<", ">": ">","&": "&", "\"": """};      
 return text.replace(/[<>&"]/g, function(character) { 
  return replacements[character]; 
 }); 
}

19.在一个loop里避免使用try-catch-finally

try-catch-finally在当前范围里运行时会创建一个新的变量,在执行catch时,捕获异常对象会赋值给变量。
不要这样使用:

var object = ['foo', 'bar'], i; 
for (i = 0, len = object.length; i <len; i++) { 
 try { 
  // 执行代码,如果出错将被捕获
 } 
 catch (e) {  
  // 获取错误,并执行代码
 } 
}

应该这样使用:

var object = ['foo', 'bar'], i; 
try { 
 for (i = 0, len = object.length; i <len; i++) { 
  // 执行代码,如果出错将被捕获
 } 
} 
catch (e) {  
 // 获取错误,并执行代码
}

20.给XMLHttpRequests设置timeouts

如果一个XHR需要花费太长时间,你可以终止链接(例如网络问题),通过给XHR使用setTimeout()解决。

var xhr = new XMLHttpRequest (); 
xhr.onreadystatechange = function () { 
 if (this.readyState == 4) { 
  clearTimeout(timeout); 
  // 执行代码
 } 
} 
var timeout = setTimeout( function () { 
 xhr.abort(); // call error callback 
}, 60*1000  ); 
xhr.open('GET', url, true); 
 
xhr.send();

此外,通常你应该完全避免同步Ajax调用。

21.处理WebSocket超时

一般来说,当创建一个WebSocket链接时,服务器可能在闲置30秒后链接超时,在闲置一段时间后,防火墙也可能会链接超时。

为了解决这种超时问题,你可以定期地向服务器发送空信息,在代码里添加两个函数:一个函数用来保持链接一直是活的,另一个用来取消链接是活的,使用这种方法,你将控制超时问题。

添加一个timeID……

var timerID = 0; 
function keepAlive() { 
 var timeout = 15000; 
 if (webSocket.readyState == webSocket.OPEN) { 
  webSocket.send(''); 
 } 
 timerId = setTimeout(keepAlive, timeout); 
} 
function cancelKeepAlive() { 
 if (timerId) { 
  cancelTimeout(timerId); 
 } 
}

keepAlive()方法应该添加在WebSocket链接方法onOpen()的末端,cancelKeepAlive()方法放在onClose()方法下面。

22.记住,最原始的操作要比函数调用快

对于简单的任务,最好使用基本操作方式来实现,而不是使用函数调用实现。
例如

var min = Math.min(a,b); 
A.push(v);

基本操作方式:

var min = a < b ? a b; 
A[A.length] = v;

23.编码时注意代码的美观、可读

JavaScript是一门非常好的语言,尤其对于前端工程师来说,JavaScript执行效率也非常重要。

关于“如何提高JavaScript执行效率”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,使各位可以学到更多知识,如果觉得文章不错,请把它分享出去让更多的人看到。

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

如何提高JavaScript执行效率

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

如何提高bitblt函数的执行效率

要提高bitblt函数的执行效率,可以考虑以下几个方面:1. 减少内存拷贝:内存拷贝是bitblt函数的主要操作之一,可以尽量减少内存拷贝的次数。可以使用双缓冲技术,将需要绘制的图像先绘制到一个内存缓冲区中,然后再一次性地拷贝到目标区域。这
2023-08-19

Task怎么提高异步执行效率

本篇内容介绍了“Task怎么提高异步执行效率”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!async Task 语法糖出来后,异步编程变得非
2023-06-29

如何提高PHP运行效率

如何提高PHP运行效率,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。提高PHP运行效率1,在函数中,传递数组时 使用 return 比使用 global 要高效比如functi
2023-06-17

如何提升 C++ 函数执行效率?

提升 c++++ 函数执行效率的技巧包括:避免不必要的复制拷贝、使用局部变量、减少函数调用开销、使用内联函数、优化循环、使用缓存。如何提升 C++ 函数执行效率?在 C++ 中编写高性能代码时,优化函数效率至关重要。以下是一些提升函数执行
如何提升 C++ 函数执行效率?
2024-04-18

如何使用Golang的同步机制提高执行效率

在Golang中,可以使用以下几种同步机制来提高执行效率:1. 互斥锁(Mutex):互斥锁可以用来保护共享资源,确保在同一时间只有一个goroutine可以访问该资源。在使用互斥锁时,需要在访问共享资源之前调用Lock方法来获取锁,在访问
2023-10-09

怎样提高bitblt函数的执行效率

要提高BitBlt函数的执行效率,可以考虑以下几个方面的优化:1. 减少函数调用次数:每次函数调用都会有一定的开销,可以将多个相邻的BitBlt操作合并为一个函数调用,减少不必要的函数调用。2. 使用更高效的图像格式:选择适合当前操作的图像
2023-08-18

Oracle提高SQL执行效率的3种方法

Oracle提供了多种方法在执行带有大量执行计划的复杂查询时剖析过程会拖累系统的性能,感兴趣的朋友可以了解下
2022-11-15

如何使用PHP7的CLI模式提高脚本的执行效率?

如何使用PHP7的CLI模式提高脚本的执行效率?PHP是一种非常流行的服务器端脚本语言,而PHP7则是PHP系列中最新版本的一个重大升级。PHP7不仅提供了许多新的特性和改进,还引入了一种命令行界面(CLI)模式,可以帮助开发者更好地使用P
2023-10-22

如何提高python效率

这篇“如何提高python效率”文章,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要参考一下,对于“如何提高python效率”,小编整理了以下知识点,请大家跟着小编的步伐一步一步的慢慢理解,接下来就让我们进入主题吧。
2023-06-06

如何提高CSS效率

小编给大家分享一下如何提高CSS效率,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!相对单位 聪明又有前瞻头脑的开发者们已经使用相对单位了—&mdash
2023-06-08

怎么使用GNU Parallel提高Linux命令行执行效率

这篇文章主要为大家展示了“怎么使用GNU Parallel提高Linux命令行执行效率”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“怎么使用GNU Parallel提高Linux命令行执行效率”
2023-06-16

使用php数据缓存技术提高执行效率

使用php缓存技术时为了提高效率。在大量的并发访问面前,获取数据可能成为效率的瓶颈,PHP实际开发之中针对数据处理进行缓存。
2022-12-14

IDEA如何提高开发效率

这篇文章给大家分享的是有关IDEA如何提高开发效率的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。一、Lombok插件Lombok项目是一个Java库,它会自动插入您的编辑器和构建工具中,从而使您的Java更加生动
2023-06-14

PHP7中的生成器:如何高效地处理大量数据和提高代码执行效率?

PHP7中的生成器:如何高效地处理大量数据和提高代码执行效率?随着互联网的快速发展和数据量的不断增长,处理大量数据成为了现代编程中的一个重要挑战。在PHP7中,引入了生成器(Generator)作为一种高效处理大量数据的机制。本文将介绍生成
2023-10-27

如何有效提高Vista搜索效率

这篇文章主要介绍“如何有效提高Vista搜索效率”,在日常操作中,相信很多人在如何有效提高Vista搜索效率问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”如何有效提高Vista搜索效率”的疑惑有所帮助!接下来
2023-06-14

编程热搜

目录