如何在 JavaScript 中检查变量是否为布尔值?
在本教程中,我们将学习如何检查 JavaScript 中的变量是否为布尔值。在 JavaScript 中,如果我们使用相等运算符匹配具有相同值但数据类型不同的两个变量,它将返回 true 值。这意味着如果我们将两个值为 true 但数据类型不同的变量(例如布尔值和字符串)进行比较,它将产生肯定的结果。
为了克服这些问题,我们需要在将变量与其他值匹配之前检查该变量是否是布尔类型。
用户可以使用以下三种方法来检查变量类型。
使用 typeof 运算符
使用严格相等运算符 (===)
使用 toString.call() 方法
使用 typeof 运算符
typeof 运算符用于检查 JavaScript 中的变量类型。它返回变量的类型。我们将返回的值与字符串 “boolean” 进行比较,如果匹配,我们可以说变量类型是布尔值。
用户可以使用以下语法使用 typeof 运算符来检查变量是否是布尔类型。
语法
typeof variable
参数
variable − 它可以是任何类型的变量。
示例
在下面的示例中,我们检查了不同变量的类型。用户可以在输出中看到结果。
<html> <head> <title>Check if variable is of boolean type</title> </head> <body> <h2>Check if variable is of boolean type in JavaScript using <i> typeof </i> operator.</h2> <h4>output for value true</h4> <div id = "result1"></div> <h4>Output for "true"</h4> <div id = "result2"></div> <script> let result1 = document.getElementById("result1"); let result2 = document.getElementById("result2"); let bool = true; result1.innerHTML = typeof bool; bool = "true"; result2.innerHTML = typeof bool; </script> </body> </html>
在上面的输出中,用户可以看到 “true” 值,它返回字符串类型,而对于 true 值,typeof 运算符返回布尔值。
使用严格相等运算符 (===)
当我们使用严格相等运算符比较两个变量时,它会比较 JavaScript 中两个变量的值和数据类型。正如用户所知,布尔数据类型有两个值:true 和 false,我们将把变量与这两个布尔值进行比较。如果其中一个匹配条件返回 true,则该变量为布尔类型。
语法
请按照以下语法使用严格相等运算符检查布尔类型变量。
If( variable === true || variable === false ) { // variable is of Boolean type. }
示例
在下面的示例中,我们将 bool name 变量与 true 和 false 布尔值进行了比较。用户可以在输出中看到结果。
<html> <head> <title>Check if variable is of boolean type</title> </head> <body> <h2>Check if variable is of boolean type in JavaScript using <i> strict equality </i> operator.</h2> <div id = "result1"></div> <script> let result1 = document.getElementById("result1"); let bool = true; if (bool === true || bool === false) { result1.innerHTML = "variable bool is type of boolean."; } else { result1.innerHTML = "variable bool is not type of boolean."; } </script> </body> </html>
使用 toString.call() 方法
在本节中,我们将学习如何使用 toString.call() 方法来检查变量是否是布尔类型。它的作用类似于 typeof 运算符,但返回不同的字符串,而不仅仅是变量的数据类型。此方法返回类似于 ‘[object data_type]’ 的字符串。
语法
用户可以按照以下语法使用 toString.call() 方法。
let result = toString.call( variable ) === '[object Boolean]'
参数
variable − 这是我们需要检查数据类型的变量。
示例
在下面的示例中,我们使用了 toString.call() 方法来检查变量类型,并将其与字符串 ‘[object boolean]’ 进行比较。如果两个字符串匹配,则变量为布尔类型。
<html> <head> <title>Check if variable is of boolean type</title> </head> <body> <h2>Check if variable is of boolean type in JavaScript using <i> tostring.call() </i> method.</h2> <div id = "result1"></div> <script> let result1 = document.getElementById("result1"); let bool = true; if ( toString.call(bool) === '[object Boolean]' ) { result1.innerHTML = "variable bool is type of boolean."; } else { result1.innerHTML = "variable bool is not type of boolean. "; } </script> </body> </html>
在本教程中,我们已经成功学习了如何检查变量是否为布尔类型。在第一种方法中,我们使用了 typeof 运算符,它也可以用于检查任何变量的数据类型。
在第三种方法中,我们使用了 toString.call() 方法,其作用与 typeof 运算符相同。但是,严格相等运算符是比调用方法更好的解决方案。