如何提升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并操作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应用程序的性能,我们可以简单地查看问题并尝试克服这些问题。