Properly Exit from a JavaScript Function. or Early...

Technically, in JavaScript, you don't need to do anything special to exit a function. A function in JavaScript that doesn't contain a return statement will exit with the default return value undefined. If the function is not recursive (a function that calls itself) or in an infinite loop, it will return some value one way or another. However, there are points to consider when writing quality code. Let's first see different ways to exit from a JavaScript function.

Methods of Exiting a Function

return

The most obvious way to exit from a function is using the return keyword quickly.

  function add(a, b) {
    return a + b;
  }

throw statement

function divide(a, b) {
    if (b === 0) throw new Error("Division by zero.");
    return a / b;
}

It's beneficial to note here that it is possible to handle exceptions in a try-catch block for a particular condition when it is not a fatal error. You may want to catch throw and return a default value.

break (huh?!)

In some sources, the break statement is also mentioned as a way to exit a function. These sources provide an example similar to the following example:

function getData() {
  body: {
    console.info("This is not the way!");
    break body;
  }
}

If you examine the above code, you can see that the break body statement doesn't exit the function; it exits the block named body. To understand this better, let's look at the following non-working (faulty) code:

body: {
  console.log("This code does not work at all!");
  function getId() {
    break body; // SyntaxError: Undefined label 'block1'
  }
}
getId();

Similarly, the following code will also not work:

function getId()  {
  console.log("This code does not work at all!");
  break; // SyntaxError: Illegal break statement
}
getId();

break is a statement to exit from the current loop when a specific condition is met.

exit (nuke)

This is a node.js specific way to exit from the node.js process. It exists from the function and terminates the program execution completely with the specific value we provided as an exit code. If you stop script execution with a non-zero value, it means an error occurred. See the following code block:

function add(a, b) {
  process.exit(1); // Stops code execution with an error code.
}

Best Practices

So, how should we exit a function? We can see a few points to pay attention to when we examine it from a code quality perspective. While these points are not strict rules of the JavaScript language, following them can be beneficial, especially if you're uncertain about what you're doing.

Consistency

JavaScript allows a function to return different data types. For example, the following code returns either a number or a string based on a given condition:

function getValue(condition) {
  if (condition) return 1;
  else return "a";
}

While the above code is not technically problematic in JavaScript, it's a disturbing example of code quality. Unless there's a particular reason, a function should return the same data type in all cases. Otherwise, bugs that are hard to find might appear in the code that uses this function.

Single Exit Point

A function should not have multiple exit points. It's hard to follow early exit points if some are in the middle of the function.

This rule is quite debatable and can vary based on personal opinions. I must confess that I don't strictly adhere to this rule. This rule assumes that functions with long bodies are difficult to follow. However, a function's body should be short; if it's long, it should be divided into sub-functions. Still, I believe sharing this rule can be helpful here.

function getData() {
   const condition = false;
   // Some code.
   // Some code.
   if (condition) return 3;
   const something = false;
   // Some code.
   // Some code.
   // Some code.
   if (something) return 2;
   const other = false;
   // Some code.
   // Some code.
   // Some code.
   if (other) return 1;
   // Some code.
   // Some code.
   // Some code.
   return 0;
}

No Empty Return

Another debatable rule. An explicit return undefined is advisable over an empty return statement because a blank return might be distracting and could accidentally have a value added to it.

function getData(condition) {
  if (condition) return undefined;
}

ESLint

We can check all return statements automatically using ESLint. ESLint is a must-use tool that statically analyzes your code to find problems quickly. There are multiple ESLint rules to check the quality of return statements. The following are the most useful ones, but you can find more if you make a Google search.

Would you like to share your thoughts about how to exit from a JavaScript function? Post your thoughts and comments below.