如何提高JavaScript的性能?

WBOY
WBOY 转载
2023-09-12 12:25:06 649浏览

如何提高JavaScript的性能?

当今世界,几乎每个网站都使用 JavaScript。 Web 应用程序变得越来越复杂,用户交互性也越来越强,这导致了性能问题。它会导致糟糕的用户体验,这对于任何 Web 应用程序来说都是不可取的。不同的因素会导致性能差、加载时间长和响应时间长。

在本教程中,我们将讨论所有这些因素以及如何解决此问题并提高 JavaScript 的性能。

轻量且紧凑的代码

提高 JavaScript 性能的第一件事就是编写轻量、紧凑的代码。 JavaScript 代码可以有多个模块和一些未使用的函数或变量,可以轻松地从代码中删除它们。它将缩短 JavaScript 的编译时间,从而获得更好的性能。此外,使用先进的算法来执行复杂的任务对于提高性能也非常有益。

使用局部变量

JavaScript 访问局部变量的速度比全局变量快,因此使用局部变量可以提高 JavaScript 的性能。每当我们访问一个变量时,JavaScript 首先在本地范围内搜索该变量,然后查找全局变量。如果所有变量都定义在本地范围内,则会减少访问它的时间。此外,局部变量在函数调用完成后会被销毁,但全局变量将其值保留在内存中。这也可能导致内存问题。

// Local variables
const id = 10
let value = 'Tutorialspoint'
// Global variables
var 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 THIS
for(let index=0; i<names.length; i++){
   element.innerHTML += names[index] + ' ';
}
// DO THIS
let 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 loop
var j = arr.length;
for (i = 0; i < j; i++) {
   // code
}

使用其他工具查找问题

您的 Web 应用程序似乎工作正常,但可能存在一些性能问题,为了找出这些问题,一些工具可能很有用。 Lighthouse 是一个有用的 Web 应用程序性能分析工具。它有助于检查性能、最佳实践、可访问性和 SEO。互联网上不仅有这个工具,还有其他工具可以用来检查 Web 应用程序的性能,我们可以简单地看到问题并尝试克服这些问题。

以上就是如何提高JavaScript的性能?的详细内容,更多请关注php中文网其它相关文章!

声明:本文转载于:tutorialspoint,如有侵犯,请联系admin@php.cn删除