break
Baseline
Widely available
This feature is well established and works across many devices and browser versions. Itâs been available across browsers since 2015å¹´7æ.
break é³è¿°å¥æä¸æ·ç®åçè¿ä»£ãswitch æ label é³è¿°å¥ï¼ä¸¦å°ç¨å¼æµç¨è½å°è¢«ä¸æ·ä¹é³è¿°å¥å¾çé³è¿°å¥ã
å試ä¸ä¸
let i = 0;
while (i < 6) {
if (i === 3) {
break;
}
i = i + 1;
}
console.log(i);
// Expected output: 3
èªæ³
break [label];
說æ
䏿·é³è¿° break å¯å 䏿¨ç±¤ (label) 忏ï¼ä½¿å
¶è·³åºè¢«æ¨ç±¤çé³è¿°èªå¥ãæ¤ä¸æ·é³è¿° break å¿
é 被å
å«å¨è¢«æ¨ç±¤çé³è¿°èªå¥ä¸ã被æ¨ç±¤çé³è¿°èªå¥å¯è¢«æ·»å æ¼ä»»ä¸ååå¡ (block) åï¼èééå®å¨è¿´åé³è¿°ã
ç¯ä¾
ä¸é¢å½å¼å
å«ä¸å䏿·é³è¿° break ï¼ç¶ i å¼çº 3 æï¼ä¸æ· while è¿´åï¼ä¸¦åå³ 3 * x ã
function testBreak(x) {
var i = 0;
while (i < 6) {
if (i == 3) {
break;
}
i += 1;
}
return i * x;
}
The following code uses break statements with labeled blocks. A break statement must be nested within any label it references. Notice that inner_block is nested within outer_block.
outer_block: {
inner_block: {
console.log("1");
break outer_block; // breaks out of both inner_block and outer_block
console.log(":-("); // skipped
}
console.log("2"); // skipped
}
The following code also uses break statements with labeled blocks but generates a Syntax Error because its break statement is within block_1 but references block_2. A break statement must always be nested within any label it references.
block_1: {
console.log('1');
break block_2; // SyntaxError: label not found
}
block_2: {
console.log('2');
}
è¦ç¯
| Specification |
|---|
| ECMAScript® 2027 Language Specification> # sec-break-statement> |