如何避免缓慢的JavaScript代码

526次阅读  |  发布于3年以前

简介

在本文中,我们将讨论如何帮助JavaScript代码良好且快速地运行。我们将通过回顾一些常见的错误,来确定如何让代码运行得更流畅、更高效。

开始吧!

未使用的变量

我敢打赌我们在使用JS的时候,在控制台中肯定看到过这些常见的错误。

variable is defined but never used(定义了变量但从未使用)

这是一个非常常见的错误,并且很多初学者往往会视若无睹,因为变量有时没有任何值。所以通常我们会假设这类变量对代码没有影响,不会对系统造成任何破坏。但是未使用的变量会导致性能问题,因为它只会占用浏览器的空间。简而言之,如果你根本不打算使用变量,就不要创建变量。

假设,你请4个朋友一起吃披萨,每个朋友吃2片,每个披萨可以分成8片。那么你叫外卖的时候,是点刚好数量的披萨,还是在已知朋友只能吃2片的情况下再多点几个披萨?从小我们就被教育不要浪费食物和金钱,所以同样的,在写代码的时候,我们为什么还要创建一个不会去用它的变量呢,浪费时间还占用了空间。

循环

在代码中进行循环时,循环会一遍又一遍地进行迭代,直到返回truefalse。这可能会给CPU带来大量繁重的工作,尤其是当包含许多对象的大数据结构中进行循环时。为了提高循环效率,我们可以将赋值或语句放在循环之外,这样就不会在只需要对属性访问一次时还每次都遍历这些属性。

例如,在下面的循环中,每次循环迭代时,都会访问arr.length,这会导致代码随着时间的推移执行缓慢,尤其是当我们工作于大型数据库并需要查找特定数据时。

var i;
for (i = 0; i < arr.length; i++) {}

为了实现更好的for循环,我们可以在for循环之外设置变量,这样就可以访问数组长度,而不必每次迭代并通过循环访问。例如,我们可以在循环外分配iarr.length并将其传入以使循环运行得更快。

var i;
var l = arr.length;
for (i = 0; i < l; i++) {}

访问循环外的长度有时可以提高可读性,就像实现了更快的循环迭代器一样。

JavaScrip加载

许多开发新手在刚开始时并不明确要将脚本标签放置在html文件中的什么位置。强烈建议将javascript脚本文件标签放在html页面的底部,以便在加载功能之前允许浏览器加载其他内容。这实际上对浏览器的加载时间产生了巨大的影响。如果脚本标记位于HTML文件的开头,那么浏览器将首先下载脚本代码,然后再从浏览器加载其他内容,甚至可能会阻塞渲染活动。你也可以在页面加载后将脚本添加到浏览器。

<script>
window.onload = function() {
  var element = document.createElement("script");
  element.src = "javaScriptCode.js";
  document.body.appendChild(element);
};
</script>

减少DOM访问

选择,或换句话说,访问HTML DOM是非常慢的。我们希望保持较少数量的所选元素,这将有助于提升加载速度,并且对较小的设备也非常有利。如果我们需要多次访问一个DOM元素,那么可以直接将它存储在一个局部变量中并且只访问一次。

var elm;
elm = document.getElementById("demo");
elm.innerHTML = "Hello";

这可能看起来没有很大的改变,但实事求是的说,在处理具有大量代码行的复杂应用程序时,哪怕是再小错误也可能会导致截然不同的结果。

结论

了解代码如何正常工作非常重要,因为不仅可以帮助你成为更好的开发人员,还可以帮助你更有效地使用工具。

感谢大家抽出宝贵的时间阅读到这里!如果你觉得文章写的对你有帮助的话,也欢迎分享给你的朋友!

Copyright© 2013-2020

All Rights Reserved 京ICP备2023019179号-8