JavaScript中表示結束當前循環有兩種方式,分別是break和continue,它們可以讓我們的程序在某些條件下跳過或中止當前的循環,從而實現更加高效的算法和代碼邏輯。下面我們分別介紹一下這兩種關鍵詞的用法和具體實現。
首先是break關鍵詞。當我們需要在一個循環內部中止整個循環,并跳出當前的代碼塊時,就可以使用break。例如,我們要在一個數組中查找某個元素是否存在:
const arr = [1, 2, 3, 4, 5]; const target = 3; let isFound = false; for(let i = 0; i < arr.length; i++) { if(arr[i] === target) { isFound = true; break; } } if(isFound) { console.log("找到了!"); } else { console.log("沒找到。"); }
在上面的代碼中,當找到元素3時,我們使用break跳出了整個循環,從而讓程序立即進入了if語句中的代碼塊,輸出“找到了!”。如果沒有找到目標元素,則isFound仍為false,程序會進入else語句中,輸出“沒找到。”。
其次是continue關鍵詞。與break不同的是,continue可以讓我們在一個循環內部跳過某些不滿足條件的元素,但不會中止整個循環。例如,在一個數組中找到所有大于3且是偶數的元素:
const arr = [1, 2, 3, 4, 5, 6]; for(let i = 0; i < arr.length; i++) { if(arr[i] <= 3 || arr[i] % 2 !== 0) { continue; } console.log(arr[i]); }
在上面的代碼中,我們使用continue跳過了所有不滿足條件的元素,只輸出了大于3且是偶數的元素4和6。注意到continue只跳過了當前的循環迭代,而不是整個循環。
除了在普通的for循環中使用break和continue,它們也可以在forEach、for...in、for...of等迭代器中使用。例如,在一個對象中找到所有值為偶數的屬性:
const obj = {
a: 1,
b: 2,
c: 3,
d: 4
};
for(let key in obj) {
if(obj[key] % 2 !== 0) {
continue;
}
console.log(${key}: ${obj[key]}
);
}
在上面的代碼中,我們使用for...in循環迭代對象的屬性,并使用continue跳過了所有不滿足條件的屬性,只輸出了值為偶數的屬性b和d。
總之,break和continue在JavaScript中都是很有用的關鍵詞,它們可以幫助我們在循環中節省時間和減少代碼冗余,提高程序的效率和可讀性。在使用時,我們應該根據具體的需求,選擇合適的關鍵詞來處理循環中的問題。