”工欲善其事,必先利其器。“—孔子《论语.录灵公》
首页 > 编程 > 掌握 JavaScript 中的循环:综合指南

掌握 JavaScript 中的循环:综合指南

发布于2024-11-09
浏览:899

MASTERING LOOPS IN JAVASCRIPT: A COMPREHENSIVE GUIDE

循环是编程的基础:使我们能够用最少的代码执行重复性任务。无论您是刚刚入门的初学者,还是希望精炼知识的经验丰富的开发人员,理解循环都将大大增强您编写高效、干净且有趣的代码的能力。

在本指南中,我们将深入探讨不同类型的循环、它们在流行编程语言中的语法,以及有关何时以及如何有效使用它们的一些提示。

什么是循环?

循环是一种编程结构/函数,它允许我们重复一组指令,直到满足特定条件。通过使用循环,我们可以避免重复、处理大型数据集并有效地机械化任务。 JavaScript 中使用循环来根据条件执行重复任务,此条件通常返回 true 或 false。

常见用例包括:

  • 迭代列表或数组
  • 运行代码一定次数
  • 搜索集合中的特定项目
  • 执行操作直到满足条件

循环类型

  1. For 循环
  2. While 循环
  3. Do-While 循环
  4. For...Of 循环
  5. For...In 循环
  6. 嵌套循环

大多数编程语言中通常存在三种主要类型的循环:

  1. For 循环
  2. While 循环
  3. Do-While 循环

让我们分解每种类型。

  1. For 循环

当您预先知道需要执行一段代码多少次时,可以使用 for 循环,它非常适合迭代数组或集合。

语法(JavaScript 示例):

示例1:

for i in range(5);
    print("Hello, World!");

在此示例中,range(5) 生成从 0 到 4 的序列。循环将运行五次,打印“Hello, World!”每次。

示例2:

for(let i = 0; i 



在此示例中,它指出;如果等于 0 的 i 小于或等于 10,则令 i = 0;增量(i)。这个 JavaScript 运算符( ) 将返回原始值并循环直到 10.

示例3:

for(let i = 0; i 



此示例实际上与前面的示例相同,不同之处在于使用美元符号 ($) 和反引号来提供将文本“For Loop Number”添加到循环的功能。

示例4:

for (let i = 20; i >= 0; i--){
    console.log(i)
}

在此示例中,它指出,令 i = 20;如果 i 大于或等于 0 则减量。自减运算将数字减1,它使用--operator.

何时使用:

当您知道确切的迭代次数或需要迭代列表、字典或数组中的元素时,请使用 for 循环。

  1. While 循环

当事先不知道迭代次数时,使用 while 循环。相反,循环将继续下去,直到不再满足指定的条件。 while 循环的不同之处在于您在外部设置变量。

语法(JavaScript 示例):

示例1:

let i = 0;
while(i 



在这个例子中可以看出变量是在外部设置的,它声明let i = 0;如果 i 小于 10 增量 (i ),则使用美元符号 ($) 和反引号来配置文本“ For While Loop”。

示例2:

let Johnpaul = 0;
while(Johnpaul 



在此示例中,代码将变量 Johnpaul 初始化为 0,并使用 while 循环打印“Hello, World!”直到约翰保罗达到 5。

何时使用:

当迭代次数未知或取决于循环内可能发生变化的条件时,请使用 while 循环。它通常用于需要持续检查的任务,例如等待用户输入。

  1. Do-While 循环

do-while 循环与 while 循环类似,但它保证循环内的代码在测试条件之前至少运行一次。这种类型的循环并非在所有语言(如 Python)中都可用,但在 JavaScript、C 和 Java 中很常见。

语法(JavaScript 示例):

示例1:

let Jude = 0;
do {
     console.log("Hello World!");
     Jude  ;
} while  (Jude 



在这种情况下,“你好,世界!”将在评估条件 (Jude

示例2:

let number = 1;
do {
    console.log("current number is: "   number);
    number  ;
} While (number 



在此示例中,数字初始化/等于 1。然后运行 ​​do 块,打印“当前数字是:”,后跟数字的值。打印后,number 增加 1,只要条件(number

何时使用:

当无论条件如何都需要循环体至少执行一次时,请使用 do-while 循环。它对于在循环内进行初始化的任务很有用。

选择正确的循环

  • For循环:当你知道确切的迭代次数或者需要
    迭代元素。

  • While 循环:当迭代次数未知且取决于
    健康)状况。

  • Do-While 循环:当您希望循环体之前至少执行一次时,即使条件最初为 false。

循环控制:中断和继续

在大多数编程语言中,您都有控制语句来管理循环执行:

  • Break:立即退出循环。
  • 继续:跳过当前迭代并移至下一个迭代。

例子:

for (let i = 0; i 



解释:

  • 循环从0迭代到9。
  • 当i为5时,break停止循环。
  • 如果 i 是偶数,则继续跳到下一次迭代而不打印。
  • 仅打印 5 以下的奇数。

循环的常见错误

  1. 无限循环:当循环的退出条件不为
    时会发生这种情况 遇见了。例如忘记在 while 循环中增加计数器。

  2. 相差一错误:当范围不是
    时,经常发生在 for 循环中 设置正确。

  3. 不必要的循环:使用优化操作或内置函数可以提高效率的循环。

最佳实践

  • 使用描述性变量:使用 i、a 或 b 等通用名称,
    尽管不是描述性的,但也算数。而是使用描述性变量名称
    如约翰、主要、伯爵、裘德、约翰保罗等,如果可能的话,
    特别是对于嵌套循环。

  • 考虑性能:在大型数据库上运行的循环可能会减慢速度
    程序。寻找优化,例如数组
    中的列表推导式 JavaScript 中的方法。

结论

循环是编程中必不可少的工具,使您能够自动执行重复任务并轻松处理复杂的数据库。通过掌握 for、while 和 do-while 循环,您将能够应对各种编码挑战。

希望这有帮助!如果您希望我添加具体的细节或示例,请告诉我,如果您在运行代码时遇到任何困难/问题,请向我询问,我将很乐意提供帮助。

快乐编码!

版本声明 本文转载于:https://dev.to/sopuluchukwu_eze/mastering-loops-in-javascript-a-comprehensive-guide-5del?1如有侵犯,请联系[email protected]删除
最新教程 更多>
  • PHP SimpleXML解析带命名空间冒号的XML方法
    PHP SimpleXML解析带命名空间冒号的XML方法
    在php 很少,请使用该限制很大,很少有很高。例如:这种技术可确保可以通过遍历XML树和使用儿童()方法()方法的XML树和切换名称空间来访问名称空间内的元素。
    编程 发布于2025-04-28
  • Python不会对超范围子串切片报错的原因
    Python不会对超范围子串切片报错的原因
    在python中用索引切片范围:二重性和空序列索引单个元素不同,该元素会引起错误,切片在序列的边界之外没有。这种行为源于索引和切片之间的基本差异。索引一个序列,例如“示例” [3],返回一个项目。但是,切片序列(例如“示例” [3:4])返回项目的子序列。索引不存在的元素时,例如“示例” [9] ...
    编程 发布于2025-04-28
  • 如何将MySQL数据库添加到Visual Studio 2012中的数据源对话框中?
    如何将MySQL数据库添加到Visual Studio 2012中的数据源对话框中?
    在Visual Studio 2012 尽管已安装了MySQL Connector v.6.5.4,但无法将MySQL数据库添加到实体框架的“ DataSource对话框”中。为了解决这一问题,至关重要的是要了解MySQL连接器v.6.5.5及以后的6.6.x版本将提供MySQL的官方Visual...
    编程 发布于2025-04-28
  • 如何限制动态大小的父元素中元素的滚动范围?
    如何限制动态大小的父元素中元素的滚动范围?
    在交互式接口中实现垂直滚动元素的CSS高度限制问题:考虑一个布局,其中我们具有与用户垂直滚动一起移动的可滚动地图div,同时与固定的固定sidebar保持一致。但是,地图的滚动无限期扩展,超过了视口的高度,阻止用户访问页面页脚。$("#map").css({ marginT...
    编程 发布于2025-04-28
  • CSS强类型语言解析
    CSS强类型语言解析
    您可以通过其强度或弱输入的方式对编程语言进行分类的方式之一。在这里,“键入”意味着是否在编译时已知变量。一个例子是一个场景,将整数(1)添加到包含整数(“ 1”)的字符串: result = 1 "1";包含整数的字符串可能是由带有许多运动部件的复杂逻辑套件无意间生成的。它也可以是故意从单个真理...
    编程 发布于2025-04-28
  • 如何解决AppEngine中“无法猜测文件类型,使用application/octet-stream...”错误?
    如何解决AppEngine中“无法猜测文件类型,使用application/octet-stream...”错误?
    appEngine静态文件mime type override ,静态文件处理程序有时可以覆盖正确的mime类型,在错误消息中导致错误消息:“无法猜测mimeType for for file for file for [File]。 application/application/octet...
    编程 发布于2025-04-28
  • 如何使用Regex在PHP中有效地提取括号内的文本
    如何使用Regex在PHP中有效地提取括号内的文本
    php:在括号内提取文本在处理括号内的文本时,找到最有效的解决方案是必不可少的。一种方法是利用PHP的字符串操作函数,如下所示: 作为替代 $ text ='忽略除此之外的一切(text)'; preg_match('#((。 &&& [Regex使用模式来搜索特...
    编程 发布于2025-04-28
  • 可以在纯CS中将多个粘性元素彼此堆叠在一起吗?
    可以在纯CS中将多个粘性元素彼此堆叠在一起吗?
    [2这里: https://webthemez.com/demo/sticky-multi-header-scroll/index.html </main> <section> { display:grid; grid-template-...
    编程 发布于2025-04-28
  • 如何从PHP中的Unicode字符串中有效地产生对URL友好的sl。
    如何从PHP中的Unicode字符串中有效地产生对URL友好的sl。
    为有效的slug生成首先,该函数用指定的分隔符替换所有非字母或数字字符。此步骤可确保slug遵守URL惯例。随后,它采用ICONV函数将文本简化为us-ascii兼容格式,从而允许更广泛的字符集合兼容性。接下来,该函数使用正则表达式删除了不需要的字符,例如特殊字符和空格。此步骤可确保slug仅包含...
    编程 发布于2025-04-28
  • 如何使用Java.net.urlConnection和Multipart/form-data编码使用其他参数上传文件?
    如何使用Java.net.urlConnection和Multipart/form-data编码使用其他参数上传文件?
    使用http request 上传文件上传到http server,同时也提交其他参数,java.net.net.urlconnection and Multipart/form-data Encoding是普遍的。 Here's a breakdown of the process:Mu...
    编程 发布于2025-04-28
  • 如何将来自三个MySQL表的数据组合到新表中?
    如何将来自三个MySQL表的数据组合到新表中?
    mysql:从三个表和列的新表创建新表 答案:为了实现这一目标,您可以利用一个3-way Join。 选择p。*,d.content作为年龄 来自人为p的人 加入d.person_id = p.id上的d的详细信息 加入T.Id = d.detail_id的分类法 其中t.taxonomy =...
    编程 发布于2025-04-28
  • 版本5.6.5之前,使用current_timestamp与时间戳列的current_timestamp与时间戳列有什么限制?
    版本5.6.5之前,使用current_timestamp与时间戳列的current_timestamp与时间戳列有什么限制?
    在时间戳列上使用current_timestamp或MySQL版本中的current_timestamp或在5.6.5 此限制源于遗留实现的关注,这些限制需要对当前的_timestamp功能进行特定的实现。 创建表`foo`( `Productid` int(10)unsigned not n...
    编程 发布于2025-04-28
  • 如何检查对象是否具有Python中的特定属性?
    如何检查对象是否具有Python中的特定属性?
    方法来确定对象属性存在寻求一种方法来验证对象中特定属性的存在。考虑以下示例,其中尝试访问不确定属性会引起错误: >>> a = someClass() >>> A.property Trackback(最近的最新电话): 文件“ ”,第1行, attributeError:SomeClass实...
    编程 发布于2025-04-28
  • 如何从Python中的字符串中删除表情符号:固定常见错误的初学者指南?
    如何从Python中的字符串中删除表情符号:固定常见错误的初学者指南?
    从python import codecs import codecs import codecs 导入 text = codecs.decode('这狗\ u0001f602'.encode('utf-8'),'utf-8') 印刷(文字)#带有...
    编程 发布于2025-04-28
  • 在PHP中如何高效检测空数组?
    在PHP中如何高效检测空数组?
    在PHP 中检查一个空数组可以通过各种方法在PHP中确定一个空数组。如果需要验证任何数组元素的存在,则PHP的松散键入允许对数组本身进行直接评估:一种更严格的方法涉及使用count()函数: if(count(count($ playerList)=== 0){ //列表为空。 } 对...
    编程 发布于2025-04-28

免责声明: 提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发到邮箱:[email protected] 我们会第一时间内为您处理。

Copyright© 2022 湘ICP备2022001581号-3