如何在 JavaScript 中获取第一个非空/未定义参数?

javascriptjavascript 2023-08-28 08:06:50 675
摘要: 在JavaScript中,很多时候我们需要在函数中查找第一个非null/未定义的参数。这可能是一项棘手的任务,但幸运的是,有一些方法可以帮助我们完成此任务使用Array.prototype.find()一个方法可用于获取JavaScript中的第一...

如何在 JavaScript 中获取第一个非空/未定义参数?

在 JavaScript 中,很多时候我们需要在函数中查找第一个非 null/未定义的参数。这可能是一项棘手的任务,但幸运的是,有一些方法可以帮助我们完成此任务

使用 Array.prototype.find()

一个方法可用于获取JavaScript 中的第一个非 null/未定义参数是 Array.prototype.find() 方法。此方法返回数组中通过给定测试的第一个元素的值。在我们的例子中,我们可以使用此方法通过检查参数是否不为 null/未定义的测试来查找第一个非 null/未定义参数。

示例

在在下面的示例中,我们定义一个函数来查找第一个非空或未定义的参数。

<html>
<head>
   <title>Example: finding first non-null arguements</title>
</head>
<body>
   <h2> Array.prototype.find() Method</h2>
   <div id="arguments"></div>
   <div id="result"></div>
   <script>
      function findFirstNonNullArgument(...args) {
         return args.find(arg => arg != null);
      }
      var result = findFirstNonNullArgument(null, undefined, "Hello", "World");
      document.getElementById("arguments").innerHTML = `Arguments: null, undefined, "Hello", "World"`;
      document.getElementById("result").innerHTML = "<br>First Non-Null Argument: " + result;
   </script>
</body>
</html>

从上面的代码中我们可以看到,findFirstNonNullArgument() 函数接受可变数量的参数,并使用 find() 方法返回第一个非 null/未定义的参数。< /p>

使用 Array.prototype.filter()

另一种可用于获取 JavaScript 中第一个非 null/未定义参数的方法是 Array.prototype.filter( )方法。此方法创建一个新数组,其中包含通过给定测试的所有元素。在我们的例子中,我们可以使用此方法通过传入检查参数是否不为 null/未定义的测试来查找第一个非 null/未定义参数。

示例

下面是完整的工作代码。

<html>
<head>
   <title>Example: finding first non-null arguements</title>
</head>
<body>
   <h2> Array.prototype.filter() Method</h2>
   <div id="arguments"></div>
   <div id="result"></div>
   <script>
      function findFirstNonNullArgument(...args) {
         return args.filter(arg => arg != null)[0];
      }
      document.getElementById("arguments").innerHTML = `Arguments: null, undefined, "Hello", "World"`;
      document.getElementById("result").innerHTML = "<br>First non-nul argument: " + findFirstNonNullArgument(null, undefined, "Hello", "World")
   </script>
</body>
</html>

从上面的代码中我们可以看到,findFirstNonNullArgument() 函数接受可变数量的参数,并使用 filter() 方法返回第一个非 null/未定义的参数。

使用for 循环

另一种可用于获取 JavaScript 中第一个非 null/未定义参数的方法是使用 for 循环。此方法循环遍历所有参数并检查每个参数是否不为空/未定义。如果它找到一个不为空/未定义的参数,它将返回该参数。

示例

下面是完整的工作代码 -

<html>
<head>
   <title>Examples</title>
</head>
<body>
   <div id="result"></div>
   <script>
      function findFirstNonNullArgument(...args) {
          for (let arg of args) {
             if (arg != null) {
                return arg;
            }
         }
      }
      document.getElementById("result").innerHTML = findFirstNonNullArgument(null, undefined, "Hello", "World")
   </script>
</body>
</html>

正如我们从上面的代码中看到的,findFirstNonNullArgument() 函数接受可变数量的参数,并使用 for 循环返回第一个非 null/未定义的参数。

结论

在本文中,我们研究了可用于获取 JavaScript 中第一个非 null/未定义参数的三种不同方法。每种方法都有其自身的优点和缺点,因此针对手头的任务选择正确的方法非常重要。