Review: Function Returning a Value

Site: Saylor Academy
Course: PRDV402: Introduction to JavaScript II
Book: Review: Function Returning a Value
Printed by: Guest user
Date: Wednesday, September 18, 2024, 9:04 PM

Description

In JavaScript, a function returns a value by returning the value in the "return" statement to where the function was called. For example:

sum = add(a,b)

When we call the add(a,b) function and it executes its return statement, that returned value will be stored in the sum variable.

return

The return statement ends function execution and specifies a value to be returned to the function caller.


Source: Mozilla, https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Statements/return
Creative Commons License This work is licensed under a Creative Commons Attribution-ShareAlike 2.5 License.

Try it


Syntax

return;
return expression;
expression Optional

The expression whose value is to be returned. If omitted, undefined is returned.

Description

The return statement can only be used within function bodies. When a return statement is used in a function body, the execution of the function is stopped. The return statement has different effects when placed in different functions:

  • In a plain function, the call to that function evaluates to the return value.
  • In an async function, the produced promise is resolved with the returned value.
  • In a generator function, the produced generator object's next() method returns { done: true, value: returnedValue }.
  • In an async generator function, the produced async generator object's next() method returns a promise fulfilled with { done: true, value: returnedValue }.

If a return statement is executed within a try block, its finally block, if present, is first executed, before the value is actually returned.


Automatic semicolon insertion

The syntax forbids line terminators between the return keyword and the expression to be returned.

return
a + b;

The code above is transformed by automatic semicolon insertion (ASI) into:

return;
a + b;

This makes the function return undefined and the a + b expression is never evaluated. This may generate a warning in the console.

To avoid this problem (to prevent ASI), you could use parentheses:

return (
  a + b
);

Examples

Interrupt a function

A function immediately stops at the point where return is called.

function counter() {
  // Infinite loop
  for (let count = 1; ; count++) {
    console.log(`${count}A`); // Until 5
    if (count === 5) {
      return;
    }
    console.log(`${count}B`); // Until 4
  }
  console.log(`${count}C`); // Never appears
}

counter();

// Logs:
// 1A
// 1B
// 2A
// 2B
// 3A
// 3B
// 4A
// 4B
// 5A


Returning a function

See also the article about Closures.

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

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