如何使用JavaScript验证输入是否为字母数字?


我们被赋予了验证输入字符串的任务,需要使用JavaScript检查它是否为字母数字。字母数字字符串仅包含数字和字母字符,包括大写或小写字符,并且不包含任何特殊字符或空格。

下面,我们将看到两种验证输入字符串的方法。

使用charCodeAt()方法

我们可以使用charCodeAt()方法获取任何字符的ASCII值。在这里,我们将遍历字符串的每个字符并检查每个字符的ASCII值。48到57之间的ASCII码表示数字字符,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循环遍历每个字符串字符。此外,我们通过传递0作为参数来使用charCodeAt()方法获取字符的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); 

在上述语法中,result变量包含基于字符串是否为字母数字的布尔值。

正则表达式解释

  • ^ - 它表示字符串的开头。

  • [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()方法的简单方法,但它效率不高,因此不推荐使用。

更新于:2023年2月16日

10K+ 次浏览

启动您的职业生涯

通过完成课程获得认证

开始学习
广告
© . All rights reserved.