JS跳出循環(huán)的5種方法總結(jié)(return、break、continue、throw等)
1、return 語(yǔ)句
首先來(lái)說(shuō) return 語(yǔ)句,僅限函數(shù)內(nèi)部使用,在函數(shù)體內(nèi)部使用 return 語(yǔ)句會(huì)導(dǎo)致函數(shù)立即返回并跳出循環(huán)
function myFunction() {
for (var i = 1; i < 5; i++) {
if (i === 3) {
return; // 當(dāng)i等于3時(shí)跳出循環(huán)并返回到調(diào)用處
}
console.log(i);
}
console.log('end') // 未執(zhí)行
}
myFunction();
// 輸出結(jié)果為:1 2只輸出了1和2,第三次循環(huán)中return跳出了循環(huán),同時(shí)也阻止了后面代碼的執(zhí)行,這就是return的特性:當(dāng)執(zhí)行return語(yǔ)句時(shí),即使函數(shù)主體中還有其他語(yǔ)句,函數(shù)執(zhí)行也會(huì)停止!
2、break 語(yǔ)句
使用 break 關(guān)鍵字來(lái)立即結(jié)束當(dāng)前所在的循環(huán)
function myFunction() {
for (var i = 1; i < 5; i++) {
if (i === 3) {
break; // 當(dāng)i等于3時(shí)跳出循環(huán)并返回到調(diào)用處
}
console.log(i);
}
console.log('end') // 執(zhí)行
}
myFunction();
// 輸出結(jié)果為:1 2 end通過(guò)輸出了 end 可以看出他跟 return 語(yǔ)句的不同之處,break 語(yǔ)句只是跳出了當(dāng)前循環(huán)語(yǔ)句,并不會(huì)阻止函數(shù)內(nèi)其他語(yǔ)句的執(zhí)行
3、 給循環(huán)體增加別名
首先我們針對(duì) for 循環(huán)設(shè)置一個(gè)常量表示循環(huán)體,然后 break 指定跳出循環(huán)體。(tips:指定的循環(huán)體可以是英文也可以是中文,只適用于 for 循環(huán),且每層都得用for循環(huán))
foo: for (var i = 1; i <= 5; i++) {
if (i === 3) {
break foo;
}
console.log(i);
}
// 輸出結(jié)果為 1 2此方法還可跳出多個(gè)循環(huán)體,如下找出第一個(gè)吃草莓的人
const arr = [
{ name: '張三', fruit: ['蘋果', '香蕉']},
{ name: '李四', fruit: ['梨', '草莓']},
{ name: '王五', fruit: ['櫻桃', '西瓜']},
{ name: '小紅', fruit: ['菠蘿', '芒果']},
]
let person = undefined
// 為緊鄰的for循環(huán)命名
冰淇淋: for (let i = 0; i < arr.length; i++) {
for (let j = 0; j < arr[i].fruit.length; j++) {
console.log(arr[i].name, arr[i].fruit[j])
if (arr[i].fruit[j] === '草莓') {
person = arr[i].name
// 跳出命名的循環(huán)
break 冰淇淋
}
}
}
console.log('這里仍然可以執(zhí)行', person)
// 執(zhí)行結(jié)果如下:
// 張三 蘋果
// 張三 香蕉
// 李四 梨
// 李四 草莓
// 這里仍然可以執(zhí)行 李四看打印的結(jié)果,不僅阻斷了命名循環(huán)的執(zhí)行,而且執(zhí)行命名循環(huán)后續(xù)的代碼
4、continue 語(yǔ)句
和 break 語(yǔ)句相似。所不同的是,它不是退出一個(gè)循環(huán),而是跳出當(dāng)前循環(huán),繼續(xù)下一輪循環(huán)。
continue 語(yǔ)句只能用在 while 語(yǔ)句、do/while 語(yǔ)句、for 語(yǔ)句(包括 for/of、for/in 語(yǔ)句)循環(huán)體內(nèi), 在其他地方使用都會(huì)引起錯(cuò)誤
function fn() {
for (var i = 1; i <= 5; i++) {
if (i === 3) {
continue;
}
console.log(i);
}
console.log('end'); // end
}
fn()
// 輸出結(jié)果為 1,2,4,5
5、throw 語(yǔ)句
通過(guò) throw 語(yǔ)句將自定義錯(cuò)誤對(duì)象拋出,從而觸發(fā) try-catch 機(jī)制進(jìn)行異常處理,達(dá)到類似跳出循環(huán)的效果。
相當(dāng)于強(qiáng)制拋錯(cuò)中斷執(zhí)行,不僅終止了循環(huán),后續(xù)代碼也不再執(zhí)行。
try {
for (var i = 0; i < 5; i++) {
if (i === 3) {
throw new Error('Jump out of loop'); // 當(dāng)i等于3時(shí)拋出錯(cuò)誤
}
console.log(i);
}
} catch (error) {
console.log(error.message); // 打印錯(cuò)誤信息
}
// 輸出結(jié)果為:0 1 2 Jump out of loop附:JavaScript中 throw和return有什么區(qū)別?
throw 和 return 在 JavaScript 中都可以用于從函數(shù)中返回值,但它們之間有一些關(guān)鍵區(qū)別:
用途:
return語(yǔ)句用于從函數(shù)中返回一個(gè)值。當(dāng)程序執(zhí)行到return語(yǔ)句時(shí),函數(shù)會(huì)立即終止,并將return語(yǔ)句后面的值返回給調(diào)用者。throw語(yǔ)句用于拋出異常。當(dāng)程序執(zhí)行到throw語(yǔ)句時(shí),程序會(huì)立即停止當(dāng)前執(zhí)行路徑,并嘗試查找適當(dāng)?shù)腻e(cuò)誤處理程序(如catch塊)。錯(cuò)誤處理:
throw語(yǔ)句用于表示錯(cuò)誤或異常情況。當(dāng)使用throw拋出異常時(shí),你通常需要在調(diào)用代碼中使用try...catch語(yǔ)句來(lái)捕獲并處理這些異常。而return語(yǔ)句只是簡(jiǎn)單地返回函數(shù)的結(jié)果,不涉及錯(cuò)誤處理。控制流:
throw語(yǔ)句會(huì)改變程序的控制流,使程序跳轉(zhuǎn)到離它最近的錯(cuò)誤處理程序(如catch塊)。如果沒(méi)有找到合適的錯(cuò)誤處理程序,程序會(huì)終止執(zhí)行。而return語(yǔ)句僅用于從函數(shù)中返回一個(gè)值,不會(huì)改變程序的控制流。
以下是一個(gè)簡(jiǎn)單的示例,說(shuō)明 throw 和 return 之間的區(qū)別:
function divide(a, b) {
if (b === 0) {
throw new Error("Division by zero"); // 拋出異常,表示錯(cuò)誤情況
}
return a / b; // 返回除法結(jié)果
}
try {
console.log(divide(10, 2)); // 輸出:5
console.log(divide(10, 0)); // 因?yàn)槌龜?shù)為零,將拋出異常
} catch (error) {
console.error(error.message); // 輸出:"Division by zero"
}
總之,throw 和 return 在 JavaScript 中都可以用于從函數(shù)中返回值,但它們的用途和行為有所不同。throw 用于表示錯(cuò)誤或異常情況,改變程序的控制流,并需要使用錯(cuò)誤處理程序(如 catch 塊)進(jìn)行捕獲和處理。而 return 用于簡(jiǎn)單地返回函數(shù)的結(jié)果,不涉及錯(cuò)誤處理。
總結(jié)
到此這篇關(guān)于JS跳出循環(huán)的5種方法(return、break、continue、throw等)的文章就介紹到這了,更多相關(guān)JS跳出循環(huán)方法內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
詳解JavaScript表單驗(yàn)證(E-mail 驗(yàn)證)
這篇文章主要為大家詳細(xì)介紹了JavaScript表單驗(yàn)證,重點(diǎn)介紹了E-mail驗(yàn)證,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-03-03
JavaScript登錄驗(yàn)證碼的實(shí)現(xiàn)
驗(yàn)證碼功能真的無(wú)處不在,為了提高網(wǎng)站的安全性,驗(yàn)證碼功能是必要的環(huán)節(jié),今天小編通過(guò)本文給大家分享js登錄驗(yàn)證碼的實(shí)現(xiàn),感興趣的朋友跟著小編一起學(xué)習(xí)吧2016-10-10
JavaScript實(shí)現(xiàn)的數(shù)字與字符串轉(zhuǎn)換功能示例
這篇文章主要介紹了JavaScript實(shí)現(xiàn)的數(shù)字與字符串轉(zhuǎn)換功能,涉及javascript數(shù)字、字符串等運(yùn)算與轉(zhuǎn)換相關(guān)操作技巧,需要的朋友可以參考下2017-08-08
layui 數(shù)據(jù)表格+分頁(yè)+搜索+checkbox+緩存選中項(xiàng)數(shù)據(jù)的方法
今天小編就為大家分享一篇layui 數(shù)據(jù)表格+分頁(yè)+搜索+checkbox+緩存選中項(xiàng)數(shù)據(jù)的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2019-09-09
Object.defineProperty()函數(shù)之屬性描述對(duì)象
這篇文章主要介紹了Object.defineProperty()函數(shù)之屬性描述對(duì)象,JavaScript?提供了一個(gè)內(nèi)部數(shù)據(jù)結(jié)構(gòu),用來(lái)描述對(duì)象的屬性,控制它的行為,比如該屬性是否可寫、可遍歷等等。這個(gè)內(nèi)部數(shù)據(jù)結(jié)構(gòu)稱為:屬性描述對(duì)象2022-09-09

