如何在 JavaScript 中验证给定数字?


在本教程中,我们将讨论如何在 JavaScript 中验证给定数字。用户可以按照每种方法下面的语法来使用它。

使用正则表达式

此方法测试或匹配输入的正则表达式。

语法

/\D/.test(input);
input.match(/^[0-9]*$/);

如果输入是数字,则测试返回 true。

示例

除了“30”、[] 和 "" 外,程序在所有情况下都成功。

<html> <body> <h2>Number validation using <i>regular expression</i></h2> <p id="numRegExpInp"></p> <div id="numRegExpBtnWrap"> <button id="numRegExpBtn">Validate</button> </div> <p id="numRegExpOut"></p> <script> var numRegExpInpArr = [30, 'Egan', true, false, 'undefined', 'NaN', '{}', null]; var numRegExpInp = document.getElementById("numRegExpInp"); var numRegExpOut = document.getElementById("numRegExpOut"); var numRegExpBtnWrap = document.getElementById("numRegExpBtnWrap"); var numRegExpBtn = document.getElementById("numRegExpBtn"); var numRegExpInpStr = ""; numRegExpInpStr += JSON.stringify(numRegExpInpArr); numRegExpInp.innerHTML = numRegExpInpStr; function numRegExpMatch(input) { if ((/^[0-9]*$/).test(input)) return "correct"; else return "wrong"; } numRegExpBtn.onclick = function() { numRegExpInpStr = ""; //numRegExpBtnWrap.style.display = "none"; numRegExpInpStr += numRegExpInpArr[0] + " is " + numRegExpMatch(numRegExpInpArr[0]) + "<br><br>"; numRegExpInpStr += "'" + numRegExpInpArr[1] + "'" + " is " + numRegExpMatch(numRegExpInpArr[1]) + "<br><br>"; numRegExpInpStr += numRegExpInpArr[2] + " is " + numRegExpMatch(numRegExpInpArr[2]) + "<br><br>"; numRegExpInpStr += numRegExpInpArr[3] + " is " + numRegExpMatch(numRegExpInpArr[3]) + "<br><br>"; numRegExpInpStr += numRegExpInpArr[4] + " is " + numRegExpMatch(undefined) + "<br><br>"; numRegExpInpStr += numRegExpInpArr[5] + " is " + numRegExpMatch(NaN) + "<br><br>"; numRegExpInpStr += numRegExpInpArr[6] + " is " + numRegExpMatch({}) + "<br><br>"; numRegExpInpStr += numRegExpInpArr[7] + " is " + numRegExpMatch(numRegExpInpArr[7]) + "<br><br>"; numRegExpOut.innerHTML = numRegExpInpStr; }; </script> </body> </html>

使用 typeof() 运算符

typeof() 运算符检查输入类型。

语法

typeof(input) === 'number'

如果类型是数字,则检查返回 true。

示例

除了 NaN 外,程序在所有情况下都成功。

<html> <body> <h2>Number validation using <i>typeof()</i></h2> <p id="numTypeInp"></p> <div id="numTypeBtnWrap"> <button id="numTypeBtn">Validate</button> </div> <p id="numTypeOut"></p> <script> var numTypeInpArr = [30, '30', 'Egan', true, false, 'undefined', '{}', '[]', null, '']; var numTypeInp = document.getElementById("numTypeInp"); var numTypeOut = document.getElementById("numTypeOut"); var numTypeBtnWrap = document.getElementById("numTypeBtnWrap"); var numTypeBtn = document.getElementById("numTypeBtn"); var numTypeInpStr = ""; numTypeInpStr += JSON.stringify(numTypeInpArr); numTypeInp.innerHTML = numTypeInpStr; function numTypeMatch(input) { if (typeof(input) === "number") return "correct"; else return "wrong"; } numTypeBtn.onclick = function() { numTypeInpStr = ""; //numTypeBtnWrap.style.display = "none"; numTypeInpStr += numTypeInpArr[0] + " is " + numTypeMatch(numTypeInpArr[0]) + "<br><br>"; numTypeInpStr += "'" + numTypeInpArr[1] + "'" + " is " + numTypeMatch(numTypeInpArr[1]) + "<br><br>"; numTypeInpStr += "'" + numTypeInpArr[2] + " is " + numTypeMatch(numTypeInpArr[2]) + "<br><br>"; numTypeInpStr += numTypeInpArr[3] + " is " + numTypeMatch(numTypeInpArr[3]) + "<br><br>"; numTypeInpStr += numTypeInpArr[4] + " is " + numTypeMatch(numTypeInpArr[4]) + "<br><br>"; numTypeInpStr += numTypeInpArr[5] + " is " + numTypeMatch(undefined) + "<br><br>"; numTypeInpStr += numTypeInpArr[6] + " is " + numTypeMatch({}) + "<br><br>"; numTypeInpStr += numTypeInpArr[7] + " is " + numTypeMatch([]) + "<br><br>"; numTypeInpStr += numTypeInpArr[8] + " is " + numTypeMatch(numTypeInpArr[8]) + "<br><br>"; numTypeInpStr += "''" + " is " + numTypeMatch('') + "<br><br>"; numTypeOut.innerHTML = numTypeInpStr; }; </script> </body> </html>

使用 isNaN() 对象

isNaN 是浏览器窗口的全局对象。

语法

!isNaN(input);

上述语法检查输入是否不是数字。此检查的否定表示输入是否是数字。

示例

除了“30”、true、false、[]、null 和 "" 外,程序在所有情况下都成功。

<html> <body> <h2>Number validation using <i>isNaN()</i></h2> <p id="numNanInp"></p> <div id="numNanBtnWrap"> <button id="numNanBtn">Validate</button> </div> <p id="numNanOut"></p> <script> var numNanInpArr = [30, 'Egan', 'undefined', 'NaN', '{}']; var numNanInp = document.getElementById("numNanInp"); var numNanOut = document.getElementById("numNanOut"); var numNanBtnWrap = document.getElementById("numNanBtnWrap"); var numNanBtn = document.getElementById("numNanBtn"); var numNanInpStr = ""; numNanInpStr += JSON.stringify(numNanInpArr); numNanInp.innerHTML = numNanInpStr; function numNanMatch(input) { if (isNaN(input)) return "wrong"; else return "correct"; } numNanBtn.onclick = function() { numNanInpStr = ""; numNanBtnWrap.style.display = "none"; numNanInpStr += numNanInpArr[0] + " is " + numNanMatch(numNanInpArr[0]) + "<br><br>"; numNanInpStr += "'" + numNanInpArr[1] + "'" + " is " + numNanMatch(numNanInpArr[1]) + "<br><br>"; numNanInpStr += numNanInpArr[2] + " is " + numNanMatch(undefined) + "<br><br>"; numNanInpStr += numNanInpArr[3] + " is " + numNanMatch(NaN) + "<br><br>"; numNanInpStr += numNanInpArr[4] + " is " + numNanMatch({}) + "<br><br>"; numNanOut.innerHTML = numNanInpStr; }; </script> </body> </html>

使用 Number.isFinite() 方法

isFinite() 函数检查输入是否有限。该方法首先将输入转换为数字,然后检查它是否有限。

该方法确保输入是一个数字,而不是正无穷大或负无穷大,也不是 NaN。

语法

Number.isFinite(input);

上述语法检查输入是否有限。

示例

程序在所有情况下都成功。

<html> <body> <h2>Number validation using <i>Number.isFinite()</i></h2> <p id="numFiniteInp"></p> <div id="numFiniteBtnWrap"> <button id="numFiniteBtn">Validate</button> </div> <p id="numFiniteOut"></p> <script> var numFiniteInpArr = [30, '30', 'Egan', true, false, 'undefined', 'NaN', '{}', '[]', null, '']; var numFiniteInp = document.getElementById("numFiniteInp"); var numFiniteOut = document.getElementById("numFiniteOut"); var numFiniteBtnWrap = document.getElementById("numFiniteBtnWrap"); var numFiniteBtn = document.getElementById("numFiniteBtn"); var numFiniteInpStr = ""; numFiniteInpStr += JSON.stringify(numFiniteInpArr); numFiniteInp.innerHTML = numFiniteInpStr; function numFiniteMatch(input) { if (Number.isFinite(input)) return "correct"; else return "wrong"; } numFiniteBtn.onclick = function() { numFiniteInpStr = ""; numFiniteBtnWrap.style.display = "none"; numFiniteInpStr += numFiniteInpArr[0] + " is " + numFiniteMatch(numFiniteInpArr[0]) + "<br><br>"; numFiniteInpStr += "'" + numFiniteInpArr[1] + "'" + " is " + numFiniteMatch(numFiniteInpArr[1]) + "<br><br>"; numFiniteInpStr += "'" + numFiniteInpArr[2] + " is " + numFiniteMatch(numFiniteInpArr[2]) + "<br><br>"; numFiniteInpStr += numFiniteInpArr[3] + " is " + numFiniteMatch(numFiniteInpArr[3]) + "<br><br>"; numFiniteInpStr += numFiniteInpArr[4] + " is " + numFiniteMatch(numFiniteInpArr[4]) + "<br><br>"; numFiniteInpStr += numFiniteInpArr[5] + " is " + numFiniteMatch(undefined) + "<br><br>"; numFiniteInpStr += numFiniteInpArr[6] + " is " + numFiniteMatch(NaN) + "<br><br>"; numFiniteInpStr += numFiniteInpArr[7] + " is " + numFiniteMatch({}) + "<br><br>"; numFiniteInpStr += numFiniteInpArr[8] + " is " + numFiniteMatch([]) + "<br><br>"; numFiniteInpStr += numFiniteInpArr[9] + " is " + numFiniteMatch(numFiniteInpArr[9]) + "<br><br>"; numFiniteInpStr += "''" + " is " + numFiniteMatch('') + "<br><br>"; numFiniteOut.innerHTML = numFiniteInpStr; }; </script> </body> </html>

使用 Number() 方法

Number() 函数检查数字是否有效。

语法

Number(input);

上述语法直接检查数字。

示例

除了“30”、true、false、[]、null 和 "" 外,程序在所有情况下都成功。

<html> <body> <h2>Number validation using <i>Number()</i></h2> <p id="numMethInp"></p> <div id="numMethBtnWrap"> <button id="numMethBtn">Validate</button> </div> <p id="numMethOut"></p> <script> var numMethInpArr = [30, 'Egan', false, 'undefined', 'NaN', '{}', '[]', null, '']; var numMethInp = document.getElementById("numMethInp"); var numMethOut = document.getElementById("numMethOut"); var numMethBtnWrap = document.getElementById("numMethBtnWrap"); var numMethBtn = document.getElementById("numMethBtn"); var numMethInpStr = ""; numMethInpStr += JSON.stringify(numMethInpArr); numMethInp.innerHTML = numMethInpStr; function numMethMatch(input) { if (Number(input)) return "correct"; else return "wrong"; } numMethBtn.onclick = function() { numMethInpStr = ""; numMethBtnWrap.style.display = "none"; numMethInpStr += numMethInpArr[0] + " is " + numMethMatch(numMethInpArr[0]) + "<br><br>"; numMethInpStr += "'" + numMethInpArr[1] + "'" + " is " + numMethMatch(numMethInpArr[1]) + "<br><br>"; numMethInpStr += numMethInpArr[2] + " is " + numMethMatch(numMethInpArr[2]) + "<br><br>"; numMethInpStr += numMethInpArr[3] + " is " + numMethMatch(undefined) + "<br><br>"; numMethInpStr += numMethInpArr[4] + " is " + numMethMatch(NaN) + "<br><br>"; numMethInpStr += numMethInpArr[5] + " is " + numMethMatch({}) + "<br><br>"; numMethInpStr += numMethInpArr[6] + " is " + numMethMatch([]) + "<br><br>"; numMethInpStr += numMethInpArr[7] + " is " + numMethMatch(numMethInpArr[7]) + "<br><br>"; numMethInpStr += "''" + " is " + numMethMatch('') + "<br><br>"; numMethOut.innerHTML = numMethInpStr; }; </script> </body> </html>

本教程向我们介绍了五种验证数字的方法。Number.isFinite() 方法是所有方法中最好的一种。其他每种方法在某些或更多情况下都会失败。

更新于:2022年11月15日

4K+ 次查看

启动你的职业生涯

完成课程获得认证

开始学习
广告