如何提高JavaScript的性能?
当今世界,几乎每个网站都使用 JavaScript。 Web 应用程序变得越来越复杂,用户交互性也越来越强,这导致了性能问题。它会导致糟糕的用户体验,这对于任何 Web 应用程序来说都是不可取的。不同的因素会导致性能差、加载时间长和响应时间长。
在本教程中,我们将讨论所有这些因素以及如何解决此问题并提高 JavaScript 的性能。
轻量且紧凑的代码
提高 JavaScript 性能的第一件事就是编写轻量、紧凑的代码。 JavaScript 代码可以有多个模块和一些未使用的函数或变量,可以轻松地从代码中删除它们。它将缩短 JavaScript 的编译时间,从而获得更好的性能。此外,使用先进的算法来执行复杂的任务对于提高性能也非常有益。
使用局部变量
JavaScript 访问局部变量的速度比全局变量快,因此使用局部变量可以提高 JavaScript 的性能。每当我们访问一个变量时,JavaScript 首先在本地范围内搜索该变量,然后查找全局变量。如果所有变量都定义在本地范围内,则会减少访问它的时间。此外,局部变量在函数调用完成后会被销毁,但全局变量将其值保留在内存中。这也可能导致内存问题。
立即学习“Java免费学习笔记(深入)”;
// Local variablesconst id = 10let value = 'Tutorialspoint'// Global variablesvar key = 'JavaScript'
减少 DOM 访问
访问 DOM 并操作它是 JavaScript 最重要的功能之一。但是过多地不必要地访问 DOM 会导致巨大的性能问题。每当我们操作 DOM 中的某个元素时,DOM 都会以更新状态刷新,如果您保持每秒更新 DOM 元素,那么每秒都会刷新 DOM。所以建议在必要的时候更新DOM。如果用户需要多次更新某个元素,那么最好将元素对象存储在变量中并使用该变量来更新 DOM。
let element = document.getElementById('element_id')element.innerHTML = 'Tutorialspoint'
减少循环迭代次数
循环是完成一些重复性任务的简单方法,但它们也会导致性能不佳。长迭代循环需要大量时间才能完成,因此最好尽可能避免使用长循环。相反,使用小循环并在循环中执行最少的任务。另外,不要在循环中访问 DOM;这将导致巨大的性能问题,因为您在每次循环迭代中都在操作 DOM。
let names = ['abc', 'xyz', 'mno', 'pqr'];let element = document.getElementById('element_id');// DON’T DO THISfor(let index=0; i<names.length; i++){ element.innerHTML += names[index] + ' ';}// DO THISlet str = '';for(let index=0; i<names.length; i++){ str += names[index];}element.innerHTML = str;
使用异步编程
异步编程是提高 Web 应用程序性能的最佳方法之一。在异步编程中,代码执行是异步完成的,因此可以轻松地同时执行多个任务。它导致数据的快速加载和快速响应。在 JavaScript 中,异步操作由 AJAX 执行,AJAX 代表异步 Javascript 和 XML。
let http = new XMLHttpRequest()http.open('GET', '...URL')http.onload = function(){ console.log(this.response); // the response}
将 JavaScript 放在页面底部
当 JavaScript 放置在页面顶部时,它会在页面加载时执行,因此需要一些额外的时间来加载整个页面。它会导致页面加载缓慢。为了解决这个问题,JavaScript 应放置在页面底部,以便 JavaScript 在加载整个页面后开始执行。
示例
<html><body> <div>Your Page Content</div> <div id='element'></div> <script> // JavaScript Code at Page's Bottom document.getElementById('element').innerHTML = 'Welcome to Tutorialspoint' </script></body></html>
消除内存泄漏
如果Web应用程序存在内存泄漏,那么应用程序将分配越来越多的内存,从而导致巨大的性能和内存问题。要解决此问题,请确保应用程序中没有内存泄漏,并检查变量是否取了过多的值。用户可以在Chrome开发工具中观察内存泄漏情况。
使用优化算法
JavaScript中的复杂任务一般会花费大量时间,这会导致性能问题,并使用优化的算法;我们可以减少执行任务所需的时间。以更优化的方式重写算法以获得最佳结果。另外,避免使用长循环、递归调用和全局变量。
创建和使用变量
在 JavaScript 中,仅创建您将使用并保存值的变量。使用以下内容并避免不必要的代码行和变量声明 -
document.write(num.copyWithin(2,0));
避免使用 with
with 关键字对 JavaScript 速度没有很好的影响。避免在代码中使用它。
更快的循环
使用循环时,请将赋值保留在循环之外。这将使循环更快 -
var i;// assignment outside the loopvar j = arr.length;for (i = 0; i < j; i++) { // code}
使用其他工具查找问题
您的 Web 应用程序似乎工作正常,但可能存在一些性能问题,为了找出这些问题,一些工具可能很有用。 Lighthouse 是一个有用的 Web 应用程序性能分析工具。它有助于检查性能、最佳实践、可访问性和 SEO。互联网上不仅有这个工具,还有其他工具可以用来检查 Web 应用程序的性能,我们可以简单地看到问题并尝试克服这些问题。