JavaScript 如何验证一个输入是否为字母数字
我们接到验证输入字符串的任务,需要用JavaScript检查它是否是字母数字字符串。字母数字字符串只包含数字和字母,包括大写或小写字符,甚至它不包含任何特殊字符或空格。
下面,我们将看到两种验证输入字符串的方法。
使用charCodeAt()方法
我们可以使用charCodeAT()方法来获取任何字符的ASCII值。在这里,我们将遍历字符串的每个字符,并检查每个字符的ASCII值。48到57之间的ASCII码代表数字字符,97到122代表小写字母字符,65到90代表大写字母字符。
因此,如果我们发现任何字符的ASCII值不在上述ASCII范围内,我们可以说该字符串不是字母数字字符串。
语法
用户可以按照下面的语法来使用charCodeAT()方法来检查输入的字符串是否是字母数字。
在上面的语法中,char是一个单字符。我们使用charCodeAT()方法来获取单个字符的ASCII值。之后,我们使用if-else语句来检查该字符的ASCII码是否在数字和字母字符的ASCII值之间。
例子1
在下面的例子中,我们已经创建了两个包含各种字符的输入字符串。同时,我们还定义了validateString()函数。在validateString()函数中,我们使用for-of循环遍历每个字符串字符。同时,我们使用charCodeAt()方法,通过传递0作为参数来获得字符的ASCII值。
之后,我们检查是否有任何字符的ASCII码不在数字和字母字符的ASCII范围内;我们可以说该字符串不是字母数字的。
使用正则表达式
我们可以使用带有新关键字的 RegExp() 构造函数来创建正则表达式。它是一个模式,我们可以用正则表达式模式来匹配输入的字符串,在此基础上,它返回一个真或假的布尔值。
语法
用户可以按照下面的语法来使用正则表达式来验证字母数字字符串。
在上述语法中,结果变量包含基于字符串是否为字母数字的布尔值。
正则表达式解释
^
- 它代表字符串的开始。-
[a-z0-9]+
- 它只代表a到z或0到9之间的字符。 -
$
- 它代表字符串的结束。 -
i -
它是正则表达式的一个标志,用于不区分大小写的字符串比较。
例2
在下面的例子中,我们通过传递各种字符串作为参数来调用 validateString() 函数。在该函数中,我们按照上面的解释创建了正则解释。之后,我们通过将正则表达式作为参考,并将输入字符串作为验证参数来使用test()方法。
如果test()方法返回true,说明输入字符串是字母数字,并且只包含数字和字母字符;否则,字符串不是字母数字。
例三
在下面的例子中,我们使用 prompt () 方法从用户那里获取字符串。之后,我们使用正则表达式来验证这个字符串,就像我们在上面的例子中使用的那样,但在这里我们使用了不同的正则表达式。
这里,[^a-zA-Z0-9]代表任何不在a到z、A到Z和0到9之间的字符。所以,如果字符串不是字母数字,test()方法返回真,如果是字母数字字符串,则返回假。
我们在本教程中学习了验证字母数字字符串的方法。我们使用了两种不同的正则表达式来验证字母数字字符串。此外,我们还学习了使用for循环和charCodeAT()方法的天真方法,但这并不节省时间,所以不推荐使用。