」工欲善其事,必先利其器。「—孔子《論語.錄靈公》
首頁 > 程式設計 > 掌握 JavaScript 中的循環:綜合指南

掌握 JavaScript 中的循環:綜合指南

發佈於2024-11-09
瀏覽:613

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]刪除
最新教學 更多>
  • 如何防止 Chrome 的自動填充更改您的字體?
    如何防止 Chrome 的自動填充更改您的字體?
    克服Chrome 的自動填充字體變更挑戰在Windows 上遇到Chrome 的自動填充功能時,您可能會遇到煩人的字體更改問題。將滑鼠懸停在已儲存的使用者名稱上時,字體大小和樣式會發生變化,從而破壞表單的對齊方式。雖然您可以對輸入套用固定寬度來緩解此問題,但更有效的解決方案是完全防止字體變更。 要實...
    程式設計 發佈於2024-11-09
  • Em 和 Rem:有什麼區別?
    Em 和 Rem:有什麼區別?
    簡介:rem和em都是CSS中的大小單位。 Rem 是 root 元素的字體大小。 Em 是本機上下文的字體大小。 em 單位 是從印刷版式世界借來的,它是一個允許設定元素的字體大小相對於其組件層次結構中最接近的聲明字體大小的單位。 rem 單元 是 root em 的縮寫,總是引用根元素(即 ...
    程式設計 發佈於2024-11-09
  • 在 Go 中使用 WebSocket 進行即時通信
    在 Go 中使用 WebSocket 進行即時通信
    构建需要实时更新的应用程序(例如聊天应用程序、实时通知或协作工具)需要一种比传统 HTTP 更快、更具交互性的通信方法。这就是 WebSockets 发挥作用的地方!今天,我们将探讨如何在 Go 中使用 WebSocket,以便您可以向应用程序添加实时功能。 在这篇文章中,我们将介绍: WebSoc...
    程式設計 發佈於2024-11-09
  • 如何在 Python 中產生字串的所有可能排列,包括處理重複項?
    如何在 Python 中產生字串的所有可能排列,包括處理重複項?
    Python 中的字串排列查找給定字串的所有可能排列可能是一項具有挑戰性的任務。然而,Python使用itertools模組提供了一個簡單的解決方案。 解決方案:itertools.permutations()itertools.permutations()方法是專門為生成排列而設計的。它接受一個可...
    程式設計 發佈於2024-11-09
  • 修正 D3.js GeoJSON 繪圖問題:如何修正纏繞順序?
    修正 D3.js GeoJSON 繪圖問題:如何修正纏繞順序?
    D3.js 錯誤繪製GeoJSON:纏繞順序問題當嘗試使用geoJSON 資料視覺化俄羅斯地區時,程式設計師遇到了一個問題其中D3.js 繪製單一黑色矩形而不是所需的地圖輪廓。這種差異是由於 geoJSON 檔案中座標的纏繞順序問題所引起的。 了解纏繞順序GeoJSON 座標可以順時針或逆時針順序排...
    程式設計 發佈於2024-11-09
  • 多重繼承的問題
    多重繼承的問題
    Java不支援類別的多重繼承,標準方法不規避此限制,因為類別可以維護狀態(使用實例變數),但介面不能。 預設方法提供了行為多重繼承的有限形式,允許一個類別透過預設方法從多個介面繼承行為。 當一個類別實作的兩個介面具有相同的預設方法時,可能會發生衝突,例如兩個介面 Alpha 和 Beta 都使...
    程式設計 發佈於2024-11-09
  • 如何避免 getImageData() 中的「畫布已被跨域資料污染」錯誤?
    如何避免 getImageData() 中的「畫布已被跨域資料污染」錯誤?
    如何避免getImageData() 中出現「畫布已被跨來源資料污染」錯誤使用getImageData( 時) 方法從畫布擷取像素數據,您可能會遇到錯誤「畫布已被跨來源資料污染」。當您嘗試存取受從其他網域載入的資料影響的畫布上的像素資料時,會發生此錯誤。 要了解此錯誤的原因,請考慮大多數瀏覽器中實現...
    程式設計 發佈於2024-11-09
  • ## Promise.all:Node.js 中是並行執行還是順序執行?
    ## Promise.all:Node.js 中是並行執行還是順序執行?
    Promise.all:Node.js 中並行執行還是順序執行? 問題: Promise.all(iterable) 是否順序處理 Promise 或並行? 答案: Promise.all 不執行 Promise;相反,它只是同時等待多個承諾。 Promise 的計算和結果由呼叫 Promise.a...
    程式設計 發佈於2024-11-09
  • 如何克服 Splinter/Selenium 中的 ElementClickInterceptedException:被其他攔截時點擊元素的指南
    如何克服 Splinter/Selenium 中的 ElementClickInterceptedException:被其他攔截時點擊元素的指南
    被其他人攔截時點擊元素:在Splinter/Selenium 中處理ElementClickInterceptedException抓取網頁時,點擊某些元素可能會具有挑戰性,因為模糊元素的存在。在 Selenium 中,當嘗試點選被另一個元素遮蔽的元素時,會引發 ElementClickInterc...
    程式設計 發佈於2024-11-09
  • Java Sound 可以播放 MP3 檔案嗎?
    Java Sound 可以播放 MP3 檔案嗎?
    Java Sound 預設不支援 MP3。對於特定 JRE 中支援的類型,請檢查 AudioSystem.getAudioFileTypes()。 有一種方法可以加入 MP3 支援。將基於 JMF 的 mp3plugin.jar 加入到專案的執行時間類別路徑中。 雖然 javax.sound.sam...
    程式設計 發佈於2024-11-09
  • HTML 創新
    HTML 創新
    HTML5 的創新方向錯誤。在某種程度上,我是一個有連續性的思考者,並尊重任何進步都是好的。然而,更進一步,語意標籤的決定是糟糕的。 這是正確的!我對那件事採取了政治態度! ⭐ 語意元素一定是由非 HTML 開發人員想到的。書面經驗沒有價值,真正的 100% 對於 HTML5 語意元素的真實非行銷...
    程式設計 發佈於2024-11-09
  • Redux 工具包:React Thunk 和 React Saga。
    Redux 工具包:React Thunk 和 React Saga。
    React Thunk 和 React Saga 是用于处理 React 应用程序中副作用的中间件库,特别是用于管理 API 调用等异步操作。两者通常与 Redux 一起使用,但用途和方法略有不同。 React Thunk 1. 概述: React ...
    程式設計 發佈於2024-11-09
  • 如何使用並發在 Go 中高效率地讀寫 CSV 檔案?
    如何使用並發在 Go 中高效率地讀寫 CSV 檔案?
    Go 中高效的 CSV 讀寫Go 中高效的 CSV 讀寫package main import ( "encoding/csv" "fmt" "log" "os" "strconv"...
    程式設計 發佈於2024-11-09
  • 以下是一些標題選項,請記住問題格式:

簡單直接:

* 如何用JavaScript動態調整輸入欄位寬度?
* 建立響應式輸入欄位:JavaScript So
    以下是一些標題選項,請記住問題格式: 簡單直接: * 如何用JavaScript動態調整輸入欄位寬度? * 建立響應式輸入欄位:JavaScript So
    動態調整輸入字段的寬度以適應其輸入動態調整輸入字段的寬度以匹配其內容長度可以增強用戶體驗防止佈局混亂。雖然設定固定寬度可能會導致多餘的空間或截斷文本,但動態方法可確保輸入欄位具有視覺吸引力和功能性。 不幸的是,使用 CSS 的 min-width 屬性來設定最小寬度不適用於輸入欄位。然而,現代瀏覽器...
    程式設計 發佈於2024-11-09
  • 如何使用 JavaScript 從 iFrame 重新導向父視窗?
    如何使用 JavaScript 從 iFrame 重新導向父視窗?
    從iFrame 重定向父視窗如果父視窗中嵌入了iFrame,則可能需要重定向父視窗視窗的位置更改為新的URL。為了實現這一點,JavaScript 提供了一個簡單的解決方案。 使用JavaScript 重新導向父視窗在iFrame 的JavaScript 程式碼中,您可以使用以下方法: 重定向最頂層...
    程式設計 發佈於2024-11-09

免責聲明: 提供的所有資源部分來自互聯網,如果有侵犯您的版權或其他權益,請說明詳細緣由並提供版權或權益證明然後發到郵箱:[email protected] 我們會在第一時間內為您處理。

Copyright© 2022 湘ICP备2022001581号-3