Js基礎-迴圈語句

来源:https://www.cnblogs.com/haloujava/archive/2023/09/11/17693416.html
-Advertisement-
Play Games

最近系統學習了vue.js 的官方腳手架create-vue的源碼,深入分析了裡面的技術實現細節,本文是我整理的源碼學習文章。 ...


迴圈語句在js當中主要用於重覆做一件事情。

js當中最主要的迴圈語句有三種,for迴圈,while迴圈和do-while迴圈

for

for 是一種經常被用到的迴圈結構

例如:控制台迴圈列印1到10 的數字

// for 括弧後跟著 三個表達式, 三個表達式用 分號(;) 隔開
// var i = 0 表示定義一個迴圈遍歷變數, 並賦初值 為 0
// i < 10 表示 一個 布爾表達式, 如果此條件為真,則會一直執行迴圈代碼塊當中的內容
// 表達式 i++ 用來迴圈更新變數,使得變數越來越接近於 布爾表達式當中的10
<script>
      for (var i = 0; i < 10; i++) {
				// 迴圈代碼塊
        console.log(i + 1);
      }
</script>

從上面的例子可以看出, var i = 0 ; 只執行一次, 然後再執行 i < 10 ,如果成立 執行 迴圈代碼塊中的內容 , 最後執行 i++ ; 然後迴圈 從 i < 10 …到 i++ 往複執行

for 語句執行過程

Untitled.png

while

while 也是一種迴圈結構,它經常作用於不知道要遍歷多少次,只知道什麼時候結束的場景。

使用while語句需要註意:在迴圈語句體內必須定義一個退出的條件, 否則會造成死迴圈

while 語句執行過程

while 迴圈通常先判斷條件表達式,然後再決定是否執行迴圈語句體中的內容

Untitled 1.png

while(布爾測試條件) {

	// 語句體
}

舉例

<script>
    // 定義迴圈變數
    var i = 1;
		// 判斷是有資格進入迴圈條件內容
    while (i < 10) {
      console.log(i);
			// 設置自增, 使得 i 滿足 大於 10 後退出
      i++;
    }
</script>

do-while

do-while 也是一種迴圈結構, 通常do-while 是 先執行迴圈體然後才判斷條件(這個正好和while相反,while是先判斷條件後執行), 條件判斷的結果影響是否下一次進入迴圈語句

所以說 do-while會至少執行一次

語法

do {
  // 迴圈體	
} while(迴圈條件判斷)

舉例

do-while至少執行一次

<script>
  do {
    console.log("執行");
	} while (false);
</script>

do-while 迴圈列印

<script>
      var i = 0;
      do {
        console.log(i);
        i++;
      } while (i < 10);
    </script>

break

break 代表終止迴圈 ,在 for ,while 和 do..while 中都可以使用

舉例:for 迴圈 break

<script>
      // 輸出列印到 5 就終止了
      for (var i = 0; i < 10; i++) {
        console.log(i);
        if (i == 5) {
          break;
        }
      }
</script>

while迴圈break

<script>
    var i = 0;
    while (i < 10) {
      console.log(i);
      if (i == 5) {
        break;
      }
      i++;
    }
</script>

do…while 迴圈 break

<script>
      var j = 0;
      do {
        console.log(j);
        j++;
        if (j == 6) {
          break;
        }
      } while (j < 10);
    </script>

雖然以上三個例子都還沒有到達條件語句結尾, 但是break 就可以提前結束迴圈

continue

continue 表示跳過某一次的迴圈進入到下次迴圈,本次條件符合,continue 後面的語句則不會被執行

舉例

for 迴圈跳過某次執行


<script>
			// 可以看到輸出結果,唯獨沒有列印 5 ,因為被 continue 跳過了
      for (var i = 0; i < 10; i++) {
        if (i == 5) {
          continue;
        }
        console.log(i);
      }
    </script>

while 迴圈跳過某次執行

<script>

    var i = 0;
    while (i < 10) {
      if (i == 5) {
        i = 6;
        continue;
      }
      console.log(i);
      i++;
    }
  </script>

do…while 跳過某次執行

<script>
      var i = 0;
      do {
        console.log(i);
        i++;
        if (i == 5) {
          i = 6;
          continue;
        }
      } while (i < 10);
    </script>

死迴圈

死迴圈是永遠也不退出的迴圈

死迴圈有時候是我們故意寫的,比如 一直執行某個任務

for 死迴圈

// for 迴圈表達式中什麼也不寫,即為 死迴圈,即不會主動退出的迴圈
for(;;) {
	// 迴圈體
}

while 死迴圈

while (true) {     console.log("run...");}

do-while 死迴圈

do { console.log("run...");} while(true);
請關於一下啦^_^

微信公眾號


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • SQL Server實例間同步登錄用戶 問題痛點:由於AlwaysOn和資料庫鏡像無法同步資料庫外實例對象,例如 登錄用戶、作業、鏈接伺服器等,導致主庫切換之後,應用連接不上資料庫或者作業不存在導致每晚跑批任務漏跑等 目前來看,作業等其他實例對象的同步還比較難實現,比如作業分為很多步驟,而且作業包含 ...
  • 本文分享自華為雲社區《Navicat 攜手華為雲GaussDB,聯合打造便捷高效的資料庫開發和建模工具方案》,作者: GaussDB 資料庫 。 近日, Navicat Premium順利完成與華為雲 GaussDB的相容性測試認證,並獲得華為雲授予的技術認證書。 Navicat 作為華為雲 Gau ...
  • 2022年4月,在 FlinkX 進行初版開源的整整四年後,技術團隊決定對FlinkX進行整體升級,並更名為 ChunJun。到目前為止,ChunJun 正式更名上線已經過了一年多了。作為一款穩定、易⽤、⾼效、批流⼀體的數據集成框架,相信各位關註著、喜愛著、使用著 ChunJun 的開發者們在過去的 ...
  • 葉正盛,玖章算術 CEO葉正盛,NineData 創始人 &CEO,原阿裡雲資料庫產品管理與解決方案部總經理,資深資料庫專家玖章算術是基礎技術領域的科技創新企業,創始團隊來自阿裡、華為等公司多位 P9 級資深專家,旗下的核心產品 NineData 致力於讓每個人都能充分利用數據和雲計算技術。Post... ...
  • 引文 在資料庫運維過程中,所使用的運維管理平臺是否存在這樣的問題: 1、預設監控粒度不夠,業務需要更細顆粒度的監控數據。 2、平臺預設的監控命令不適合,需要調整閾值量身定製監控策略。 3、不同類型的實例或組件需要有不同的監控重點,但管理平臺監控固化,難以應對多樣化的監控需求。 4、只監控系統關鍵指標 ...
  • 項目結構 my-vue3-project ├─ .env //預設環境變數 ├─ .env.development //開發環境變數 ├─ .eslintrc-auto-import.json //(autoimport變數,eslint配置)由auto-import插件生成 ├─ .eslintr ...
  • 介紹 ESLint 是一個根據方案識別並報告 ECMAScript/JavaScript 代碼問題的工具,其目的是使代碼風格更加一致並避免錯誤。在很多地方它都與 JSLint 和 JSHint 類似,除了: ESLint 使用 Espree 對 JavaScript 進行解析。 ESLint 在代碼 ...
  • 1. 安裝 vue-i18n npm i vue-i18n -S 2. 創建一個i8n的配置文件 如:i18nConfig.js // 配置 vue-i18n 實現國際化語言設置 import { createI19n } from 'vue-i18n' import zh_cn from '../ ...
一周排行
    -Advertisement-
    Play Games
  • 示例項目結構 在 Visual Studio 中創建一個 WinForms 應用程式後,項目結構如下所示: MyWinFormsApp/ │ ├───Properties/ │ └───Settings.settings │ ├───bin/ │ ├───Debug/ │ └───Release/ ...
  • [STAThread] 特性用於需要與 COM 組件交互的應用程式,尤其是依賴單線程模型(如 Windows Forms 應用程式)的組件。在 STA 模式下,線程擁有自己的消息迴圈,這對於處理用戶界面和某些 COM 組件是必要的。 [STAThread] static void Main(stri ...
  • 在WinForm中使用全局異常捕獲處理 在WinForm應用程式中,全局異常捕獲是確保程式穩定性的關鍵。通過在Program類的Main方法中設置全局異常處理,可以有效地捕獲並處理未預見的異常,從而避免程式崩潰。 註冊全局異常事件 [STAThread] static void Main() { / ...
  • 前言 給大家推薦一款開源的 Winform 控制項庫,可以幫助我們開發更加美觀、漂亮的 WinForm 界面。 項目介紹 SunnyUI.NET 是一個基於 .NET Framework 4.0+、.NET 6、.NET 7 和 .NET 8 的 WinForm 開源控制項庫,同時也提供了工具類庫、擴展 ...
  • 說明 該文章是屬於OverallAuth2.0系列文章,每周更新一篇該系列文章(從0到1完成系統開發)。 該系統文章,我會儘量說的非常詳細,做到不管新手、老手都能看懂。 說明:OverallAuth2.0 是一個簡單、易懂、功能強大的許可權+可視化流程管理系統。 有興趣的朋友,請關註我吧(*^▽^*) ...
  • 一、下載安裝 1.下載git 必須先下載並安裝git,再TortoiseGit下載安裝 git安裝參考教程:https://blog.csdn.net/mukes/article/details/115693833 2.TortoiseGit下載與安裝 TortoiseGit,Git客戶端,32/6 ...
  • 前言 在項目開發過程中,理解數據結構和演算法如同掌握蓋房子的秘訣。演算法不僅能幫助我們編寫高效、優質的代碼,還能解決項目中遇到的各種難題。 給大家推薦一個支持C#的開源免費、新手友好的數據結構與演算法入門教程:Hello演算法。 項目介紹 《Hello Algo》是一本開源免費、新手友好的數據結構與演算法入門 ...
  • 1.生成單個Proto.bat內容 @rem Copyright 2016, Google Inc. @rem All rights reserved. @rem @rem Redistribution and use in source and binary forms, with or with ...
  • 一:背景 1. 講故事 前段時間有位朋友找到我,說他的窗體程式在客戶這邊出現了卡死,讓我幫忙看下怎麼回事?dump也生成了,既然有dump了那就上 windbg 分析吧。 二:WinDbg 分析 1. 為什麼會卡死 窗體程式的卡死,入口門檻很低,後續往下分析就不一定了,不管怎麼說先用 !clrsta ...
  • 前言 人工智慧時代,人臉識別技術已成為安全驗證、身份識別和用戶交互的關鍵工具。 給大家推薦一款.NET 開源提供了強大的人臉識別 API,工具不僅易於集成,還具備高效處理能力。 本文將介紹一款如何利用這些API,為我們的項目添加智能識別的亮點。 項目介紹 GitHub 上擁有 1.2k 星標的 C# ...