return

Baseline Widely available

This feature is well established and works across many devices and browser versions. It’s been available across browsers since July 2015.

return 表達式會終止函式執行,並指明函式呼叫器(function caller)要回傳的數值。

嘗試一下

語法

return [[expression]];
expression

要被回傳的表達式。如果省略了表達式,函式就會回傳 undefined

敘述

如果在 function body 內宣告 return 的話,函式執行就會終止。如果指定數值的話,函式呼叫器就會回傳給定的數值。例如說,以下函式會回傳 x 參數的次方數。

js
function square(x) {
  return x * x;
}
var demo = square(3);
// demo will equal 9

如果省略了表達式,函式就會回傳 undefined

以下所有的 return 宣告都會終止函式執行:

js
return;
return true;
return false;
return x;
return x + y / 3;

自動插入分號

return 宣告會受自動插入分號(automatic semicolon insertion,ASI)影響。No line terminator is allowed between the return keyword and the expression.

js
return;
a + b;

會因為 ASI 而變成:

js
return;
a + b;

主控台會警告「unreachable code after return statement」(在 return 宣告後面有無法抵達的程式碼)。

備註: 從 Gecko 40 開始,如果主控台發現在 return 宣告後面有無法抵達的程式碼,就會顯示警告。

要避免 ASI 問題,可以添加括號:

js
return a + b;

示例

終止函式

在到達呼叫 return 的地方後,函式會立即停止。

js
function counter() {
  for (var count = 1; ; count++) {
    // 無限迴圈
    console.log(count + "A"); // 直到 5
    if (count === 5) {
      return;
    }
    console.log(count + "B"); // 直到 4
  }
  console.log(count + "C"); // 永不顯示
}

counter();

// 輸出:
// 1A
// 1B
// 2A
// 2B
// 3A
// 3B
// 4A
// 4B
// 5A

函式回傳

請參見閉包

js
function magic(x) {
  return function calc(x) {
    return x * 42;
  };
}

var answer = magic();
answer(1337); // 56154

規範

Specification
ECMAScript Language Specification
# sec-return-statement

瀏覽器相容性

Report problems with this compatibility data on GitHub
desktopmobileserver
Chrome
Edge
Firefox
Opera
Safari
Chrome Android
Firefox for Android
Opera Android
Safari on iOS
Samsung Internet
WebView Android
WebView on iOS
Deno
Node.js
return

Legend

Tip: you can click/tap on a cell for more information.

Full support
Full support

參見