如何使用JavaScript验证输入是否为字母数字
我们被要求验证输入字符串,并使用JavaScript检查它是否为字母数字。字母数字字符串只包含数字和字母字符,包括大写或小写字母字符,甚至不包含任何特殊字符或空格。
下面,我们将看到两种验证输入字符串的方法。
使用charCodeAt()方法
我们可以使用charCodeAt()方法获取任何字符的ASCII值。在这里,我们将遍历字符串的每个字符,并检查每个字符的ASCII值。ASCII码在48到57之间为数字字符,97到122为小写字母字符,65到90为大写字母字符。
因此,如果我们找到任何ASCII值不在上述给定的ASCII范围内的字符,我们就可以说该字符串不是字母数字。
语法
用户可以按照下面的语法使用charCodeAt()方法来检查输入字符串是否为字母数字。
let charCode = char.charCodeAt(0);
if (!(charCode > 47 && charCode < 58) &&
!(charCode > 96 && charCode < 123) &&
!(charCode > 64 && charCode < 91)
) {
// string is not alphanumeric
return;
}
在上面的语法中,char是一个单个的字符。我们使用charCodeAt()方法获取单个字符的ASCII值。之后,我们使用if-else语句来检查字符的ASCII码是否在数字和字母字符的ASCII值之间。
示例1
在下面的示例中,我们创建了两个包含不同字符的输入字符串。还定义了validateString()函数。在validateString()函数中,我们使用for-of循环遍历每个字符串字符。同时,我们使用charCodeAt()方法,将0作为参数传递,获取字符的ASCII值。 之后,我们检查任何字符的ASCII码是否不在数字和字母字符的ASCII范围内;我们可以说字符串不是由字母和数字组成的。
<html>
<body>
<h3>Using the <i> for loop and charCodeAT() method </i> to check if input string is alphanumeric or not</h3>
<div id = "output"> </div>
<script>
var output = document.getElementById('output');
let str1 = "aredsUADFSKH121342kjbrewdfv";
let str2 = "dfdrg rflrtke 435 3df;fd'gfdg";
function validateString(string) {
for (let char of string) {
let charCode = char.charCodeAt(0);
if (!(charCode > 47 && charCode < 58) && !(charCode > 96 && charCode < 123) && !(charCode > 64 && charCode < 91)
) {
output.innerHTML += "The string " + string + " is not alphanumeric! </br>";
return;
}
}
output.innerHTML += "The string " + string + " is an alphanumeric! </br>";
}
validateString(str1);
validateString(str2);
</script>
</body>
</html>
使用正则表达式
我们可以使用带有new关键字的RegExp()构造函数创建正则表达式。它是一个模式,我们可以使用正则表达式模式匹配输入字符串,根据匹配结果返回一个true或false的布尔值。
语法
用户可以按照以下语法使用正则表达式来验证包含字母和数字的字符串。
let strRegex = new RegExp(/^[a-z0-9]+$/i);
let result = strRegex.test(string);
在上述语法中,结果变量包含基于字符串是否是字母数字的布尔值。
正则表达式解释
^
- 它表示字符串的开始。-
[a-z0-9]+
- 它表示只有a到z或0到9之间的字符。 -
$
- 它表示字符串的结束。 -
i
- 它是用于不区分大小写字符串比较的正则表达式的标志。
示例2
在下面的示例中,我们通过将各种字符串作为参数传递来调用validateString()函数。在函数中,我们创建了如上所述的正则表达式解释。之后,我们使用了test()方法,以正则表达式作为参考并将输入字符串作为验证参数进行验证。
如果test()方法返回true,则输入字符串是字母数字,并且仅包含数字和字母字符;否则,字符串不是字母数字。
<html>
<body>
<h3>Using the <i> Regular expression </i> to check if input string is alphanumeric or not</h3>
<div id = "output"> </div>
<script>
var output = document.getElementById('output');
let str1 = "Welcome to the tutorialsPoint";
let str2 = "Hello123";
function validateString(string) {
// Defining the regular expression
let strRegex = new RegExp(/^[a-z0-9]+$/i);
// match the regex with the string
let result = strRegex.test(string);
if (result) {
output.innerHTML += "The string " + string + " is an alphanumeric! </br>";
} else {
output.innerHTML += "The string " + string + " is not alphanumeric! </br>";
}
}
validateString(str1);
validateString(str2);
</script>
</body>
</html>
示例3
在下面的示例中,我们使用prompt()方法从用户那里获取字符串。之后,我们使用正则表达式验证该字符串,就像我们在上面的示例中使用的那样,但是在这里我们使用了不同的正则表达式。
这里,[^a-zA-Z0-9]表示除了字母a到z、A到Z和数字0到9之外的任何字符。因此,如果字符串不是字母数字字符串,则test()方法返回true,否则返回false。
<html>
<body>
<h3>Using the <i> Regular expression </i> to check if input string is alphanumeric or not</h3>
<div id = "output"> </div>
<button onClick = "getInputAndValidate()"> Validate random string </button>
<script>
var output = document.getElementById('output');
function getInputAndValidate() {
let string = prompt("Enter a string to validate", "1232dwe");
let strRegex = new RegExp(/[^a-zA-Z0-9]/);
// match the regex with the string
let result = strRegex.test(string);
if (!result) {
output.innerHTML += "The string " + string + " is an alphanumeric! </br>";
} else {
output.innerHTML += "The string " + string + " is not alphanumeric! </br>";
}
}
</script>
</body>
</html>
在本教程中,我们学习了如何验证包含字母和数字的字符串。我们使用了两种不同的正则表达式来验证这样的字符串。此外,我们还学习了使用for循环和charCodeAT()方法的朴素方法,但是这个方法在时间上不高效,因此不推荐使用。