如何在 JavaScript 中终止脚本?

javascriptweb developmentfront end technology

脚本终止意味着它停止执行 JavaScript 代码。在某些紧急情况下,开发人员需要在脚本执行过程中中止 JavaScript 代码的执行。

此外,我们可以使用 if-else 语句来决定何时终止脚本执行以及何时继续。在这里,我们将学习中途终止脚本的不同方法。

使用 Return 语句

return 语句用于终止脚本内任何代码的执行。一旦我们在函数内执行 return 语句,return 语句后编写的代码将不会执行。但是,我们不需要使用 return 语句返回任何值,因为我们只需使用 return 关键字即可。

语法

用户可以按照以下语法使用 return 语句在 JavaScript 中终止脚本的执行。

function execute() {

    // 此代码将被执行
    return;
    
    // 此代码将不被执行。
}

在上述语法中,我们在函数中使用了 return 语句。

示例

在下面的示例中,每当文档加载到网页上时,我们都会调用 execute() 函数。在 execute() 函数中,我们检查数组的第一个值是否存在并继续执行;否则,我们执行 return 语句以停止脚本的执行。

<html>
<body>
   <h3>Using the <i> return statement </i> to terminate the script in JavaScript</h3>
   <div id = "content"> </div>
   <script>
      let content = document.getElementById("content");
      let array = [];
      function execute() {
         content.innerHTML = "This is a JavaScript code.";
         if (!array[0]) {
            return;
         }
         content.innerHTML = "This statment will not execute!";
      }
      execute();
   </script>
</body>
</html>

在输出中,用户可以观察到函数的最后一条语句未作为 if 语句求真条件执行,并且执行了 return 语句。

抛出错误以终止脚本

我们可以使用 throw 关键字抛出自定义错误。我们可以使用 Error() 构造函数创建一个新错误。我们可以从脚本内部的任何位置抛出错误以停止执行。当我们抛出错误时,它不会执行在 throw 语句之后编写的语句。

语法

用户可以按照以下语法在 JavaScript 中抛出错误以终止脚本的执行。

throw new Error("Error_Message");

在上述语法中,"Error_message"是向用户显示的错误信息。

示例

在下面的示例中,我们使用来自 execute() 函数的 throw 关键字抛出错误。此外,我们还触发了 try-catch 块内的函数调用来处理错误。用户可以在输出中观察到,在我们抛出错误后,脚本将停止执行。

<html>
<body>
   <h3>Throwing the <i> error </i> to terminate the script in JavaScript.</h3>
   <div id = "content"> </div>
   <script>
      let content = document.getElementById("content");
      let array = [];
      function execute() {
         throw new Error("This is an error to stop execution!");
         content.innerHTML += "This statement will not execute!";
      }
      try {
         execute();
      }
      catch (err) {
         content.innerHTML += "Error: " + err.message;
      }
   </script>
</body>
</html>

使用 clearInterval() 方法

clearInterval() 方法将计时器的 id 作为参数来清除计时器。我们可以设置计时器来执行任何功能。例如,我们可以使用 setTimeOut() 方法在延迟一段时间后执行一些脚本。如果我们需要停止脚本的执行,我们可以在脚本执行之前使用 clearInterval() 方法清除超时。

语法

用户可以按照以下语法使用 clearInterval() 方法终止脚本的执行。

let timeVar = setTimeout(() => {

    // 停止执行此脚本
},delay);
clearInterval(timeVar);

在上述语法中,我们可以停止执行 setTimeOut() 方法的回调函数中编写的脚本。

示例

在下面的示例中,我们使用 setTimeOut() 方法在延迟 2000 毫秒后执行脚本。此外,我们将计时器的 ID 存储在 timeVar 变量中。

我们在脚本执行之前使用 clearInterval() 方法清除计时器,这就是我们可以停止 JavaScript 中任何脚本执行的方法。

<html>
<body>
   <h3>Using the <i> clearInterval() method </i> to terminate the script in JavaScript.</h3>
   <div id = "content"> </div>
   <script>
      let content = document.getElementById("content");
      let timeVar = setTimeout(() => {
         content.innerHTML = "This is inside the setTimeOut() function!";
      }, 2000);
      content.innerHTML = "This is outside the setTimeOut() function!";
      clearInterval(timeVar); // This will clear the setTimeOut() function.
   </script>
</body>
</html>

在 Node.js 中使用 process.exit() 方法

process.exit() 不适用于原生 JavaScript,它只适用于 Node.js,因为我们需要导入"process"模块。我们可以通过传递 0 作为参数来执行 process.exit() 方法来终止脚本。

语法

用户可以按照以下语法使用 process.exit() 方法终止脚本。

process.exit(0);

在上述语法中,我们已传递 0 作为终止目的的参数。

示例

在下面的示例中,我们编写了 JavaScript 代码。我们在代码中导入了处理模块。我们已将 30 分配给"num"变量。 if 语句条件始终为真,因此它将停止代码的执行,我们可以在输出中观察到这一点。

// 导入流程模块
var process = require('process');
let num = 30;
console.log("number 的值为 " + num);
if(num > 20) {
    process.exit(0);
}
console.log("调用 process.exit() 时不会打印此行");

我们学习了在 JavaScript 中终止脚本的各种方法。第一种方法是使用 return 语句,第二种方法是抛出错误,第三种是使用 clearInterval() 方法,最后一种是使用 process.exit() 方法。

使用 return 语句终止脚本是最好的,但它只能在函数内部工作。 clearInterval() 方法仅在 setTImeOut() 方法执行脚本之前立即终止脚本。 process.exit() 只对 NodeJS 有用。


相关文章