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
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...