0

0

如何使用 JavaScript 验证输入是字母数字还是非字母数字?

王林

王林

发布时间:2023-08-24 10:33:02

|

1403人浏览过

|

来源于tutorialspoint

转载

如何使用 javascript 验证输入是字母数字还是非字母数字?

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

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

使用 charCodeAt() 方法

我们可以使用 charCodeAT() 方法来获取任意字符的 ASCII 值。在这里,我们将遍历字符串的每个字符并检查每个字符的 ASCII 值。 48 到 57 之间的 ASCII 码表示数字字符,97 到 122 之间表示小写字母字符,65 到 90 之间表示大写字母字符。

因此,如果我们发现任何字符的 ASCII 值不在上面给定的 ASCII 范围之间,我们就可以说该字符串不是字母数字。

立即学习Java免费学习笔记(深入)”;

语法

用户可以按照以下语法使用 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 布尔值。

语法

用户可以按照以下语法使用正则表达式来验证字母数字字符串。

Mokker AI
Mokker AI

AI产品图添加背景

下载
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() 方法的简单方法,但它的时间效率不高,因此不推荐。

java速学教程(入门到精通)
java速学教程(入门到精通)

java怎么学习?java怎么入门?java在哪学?java怎么学才快?不用担心,这里为大家提供了java速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
js正则表达式
js正则表达式

php中文网为大家提供各种js正则表达式语法大全以及各种js正则表达式使用的方法,还有更多js正则表达式的相关文章、相关下载、相关课程,供大家免费下载体验。

531

2023.06.20

正则表达式不包含
正则表达式不包含

正则表达式,又称规则表达式,,是一种文本模式,包括普通字符和特殊字符,是计算机科学的一个概念。正则表达式使用单个字符串来描述、匹配一系列匹配某个句法规则的字符串,通常被用来检索、替换那些符合某个模式的文本。php中文网给大家带来了有关正则表达式的相关教程以及文章,希望对大家能有所帮助。

258

2023.07.05

java正则表达式语法
java正则表达式语法

java正则表达式语法是一种模式匹配工具,它非常有用,可以在处理文本和字符串时快速地查找、替换、验证和提取特定的模式和数据。本专题提供java正则表达式语法的相关文章、下载和专题,供大家免费下载体验。

766

2023.07.05

java正则表达式匹配字符串
java正则表达式匹配字符串

在Java中,我们可以使用正则表达式来匹配字符串。本专题为大家带来java正则表达式匹配字符串的相关内容,帮助大家解决问题。

219

2023.08.11

正则表达式空格
正则表达式空格

正则表达式空格可以用“s”来表示,它是一个特殊的元字符,用于匹配任意空白字符,包括空格、制表符、换行符等。本专题为大家提供正则表达式相关的文章、下载、课程内容,供大家免费下载体验。

357

2023.08.31

Python爬虫获取数据的方法
Python爬虫获取数据的方法

Python爬虫可以通过请求库发送HTTP请求、解析库解析HTML、正则表达式提取数据,或使用数据抓取框架来获取数据。更多关于Python爬虫相关知识。详情阅读本专题下面的文章。php中文网欢迎大家前来学习。

293

2023.11.13

正则表达式空格如何表示
正则表达式空格如何表示

正则表达式空格可以用“s”来表示,它是一个特殊的元字符,用于匹配任意空白字符,包括空格、制表符、换行符等。想了解更多正则表达式空格怎么表示的内容,可以访问下面的文章。

245

2023.11.17

正则表达式中如何匹配数字
正则表达式中如何匹配数字

正则表达式中可以通过匹配单个数字、匹配多个数字、匹配固定长度的数字、匹配整数和小数、匹配负数和匹配科学计数法表示的数字的方法匹配数字。更多关于正则表达式的相关知识详情请看本专题下面的文章。php中文网欢迎大家前来学习。

547

2023.12.06

Python异步编程与Asyncio高并发应用实践
Python异步编程与Asyncio高并发应用实践

本专题围绕 Python 异步编程模型展开,深入讲解 Asyncio 框架的核心原理与应用实践。内容包括事件循环机制、协程任务调度、异步 IO 处理以及并发任务管理策略。通过构建高并发网络请求与异步数据处理案例,帮助开发者掌握 Python 在高并发场景中的高效开发方法,并提升系统资源利用率与整体运行性能。

37

2026.03.12

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号