【你也能从零基础学会网站开发】Web建站之javascript入门篇 简单认识一下正则表达式

本文主要是介绍【你也能从零基础学会网站开发】Web建站之javascript入门篇 简单认识一下正则表达式,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

🚀 个人主页 极客小俊
✍🏻 作者简介:程序猿、设计师、技术分享
🐋 希望大家多多支持, 我们一起学习和进步!
🏅 欢迎评论 ❤️点赞💬评论 📂收藏 📂加关注

为什么使用正则表达式

在这之前曾有过字符验证例子,其中验证字符的代码非常繁琐冗长。

有了正则表达式,验证程序的代码变得简洁而更强大,代码运行的速度更快。

举个栗子

为了判断某个字符串是否符合某种格式,使用正规表达的最为合适。通常,人们在表单数据发送到服务器之前,都需要进行数据合法性验证。

例如,客户所填写的电子邮件地址格式是否正确等。
使用正则表达式可以使程序代码简单高效

RegExp对象

RegExp是JavaScript提供的一个对象,用来完成有关正则表达式的操作和功能,每一条正则表达式模式对应一个RegExp实例。

JavaScript使用RegExp对象封装与正则表达式相关的功能和操作,每一个该对象的实例对应着一条正则表达式。

和其他对象一样,在使用之前必须取得其引用或新建一个对象实例。

语法如下

var regObj = new RegExp( 'pattern' [,'flags'] );

参数说明

pattern:必选项,正则表达式的字符串。
flags:可选项,是一些标志组合。

在标志组合中,g表示全局标志。
设定时将搜索整个字符串,以找匹配的内容,每一次新的探索都从RegExp对象的lastIndex标记的字符起,否则只搜索到第一个匹配的内容。i表示忽略大小写标志,若设置该项,则在搜索匹配项时忽略大小写,否则将区别大小写。以上所述是创建正则表达式对象的方式之一,另一种创建方式如下

var regObj = /pattern/[flags];

参数的意义和第一种方式一样,但这种方式不能用引号将pattern和flags括起来。正则表达式的使用非常简单,只要用一个test方法就行了,如下所示:

regObj.test( string );

regObj表示正则表达式对象,是一个RegExp对象实例。
string为源字符串,即将在其中进行匹配操作的字符串。

test方法返回一个布尔值,表明是否已经在源串中找到了正则表达式所定义的模式。

元字符

元字符是正则表达式最为简单的情况。它指的是与字符序列相匹配

举个栗子

var filter = /一枪爆头/g;		// 将受限制的词句组成正则表达式
var said = "他被人一枪爆头了";	// 将接受检查的语句
if (filter.test(said))		    // 如果被检查语句中存在受限词句
{alert("该语句中有限制级词语,系统已经过滤!");   // 显示警告
} else			// 否则
{alert(said);// 输出原话
}

量词

量词就是指定某个特定模式出现的次数。分为简单量词、贪婪量词、惰性量词和支配量词几种。

目前IE浏览器并没有实现这些特性,下面简单的介绍这几种量词。
贪婪量词,它是首先匹配整个字符串,如果不匹配,则去掉最后一个字符,然后再比较。如果仍然不匹配,则继续去掉最后一个字符再比较,如此一直下去,直到找到匹配或者字符串的字符被取完为止。
惰性量词是先看字符串中的第一个字符是不是匹配。如果不匹配,就读入下一个字符,将这两个字符连接成一个字符串。如果还是不匹配,则继续从字符串添加字符直到发现匹配或找完整个字符串为止。

支配量词,它只尝试整个字符串的匹配,如果不能匹配,则不再尝试,也就说它只比较一次。

举个栗子

我们可以来写一个简单的程序来判断用户名是否合法

function check() {var use = username.value;			//取得用户的输入var regx = /[a-z0-9]\w\d/g;			//验证输入的正则表达式if (!regx.test(use)) 			//不包含规定字符,用户名无效{alert("\n用户名检测 : \n\n结果 : 用户名不合法! \n");username.focus();			//获得焦点} else {alert("\n用户名检测 : \n\n结果 : 用户名合法! \n");//提示用户输入合法}
}
<input type="text" id="username" value="">
<input type="submit" value="合法性检测" onClick="check()">

分组模式

前面用简单模式可以找整个表达式的结果,但是如果要找的是表达式内的子表达,或者找的是目标字符串中重复出现子串,则仅仅依靠前面的简单模式的知识是绝对无法实现的。

为了解决上面的问题,正则表达式引入分组的概念。
它的语法是“(pattern)”,也就是用括号括起一些字符、字符类或量词,它是一个组合项或子匹配,可统一操作。

举个栗子

var showStr = "";				//定义一个变量,并赋空值
var str = "this word is OKOKOKOKokokokok!!!"; 		//给变量赋初值
var searchStr = /(OK){2}/gi; 			//分组的正则表达式
var result = str.match(searchStr); 			//查找匹配
for (var i = 0; i < result.length; i++)			//循环访问arrdata对象
{showStr += result[i] + "\n"; 			//显示信息
}
alert("一共有" + result.length + "组匹配\n" + showStr);		//显示最后匹配的结果

候选模式

候选就是用“|”来表示的模式或关系,它表示的是在匹配时可以匹配“|”的左边或右边。这个“|”相当于“或”。
这个功能一般用在检验某个指定的字符串是否存在。

举个栗子

var str1 = "I like red and black";// 给字符串赋初值
var str2 = "she likes black"; // 给字符串赋初值
var result = /(red|black)/;	//候选正则表达式
reStr=result.test(str1);	//用test方法检查字符串是否存在
alert(result.test(str2));	//返回的值为bool型,即true或flase,这里返回的是true
alert(reStr)		//返回true

邮箱验证

验证电子邮件
正确格式的电子邮件地址如xx1209@163.com,它必须符合以下几个条件。电子邮件地址中同时含有@.字符;字符@后必须有字符“.”,且中间至少间隔一个字符;字符“@”不为第一个字符,“.”不为最后一个字符。

所有的电子邮件都是这样的。
根据上述条件,可构造验证电子邮件地址的正则表达式如下所示:/^([a-zA-Z0-9_-])+@([a-zA-Z0-9_-])+(\.[a-zA-Z0-9_-])+/

举个栗子

function check(obj) {var emailUrl = obj.email.valuevar regex = /^([a-zA-Z0-9_-])+@([a-zA-Z0-9_-])+(\.[a-zA-Z0-9_-])+/; 	//构造正则表达式进行检验if (!regex.exec(emailUrl)) 				//取得用户的输入{alert("您输入的格式有误,可能您好忘记了@符号或是点号!请重新输入");obj.m_email.focus()			//取得焦点} else {alert("输入正确!");			//通过验证return true;				//提交表单}
}
<center><p>验证电子邮件地址合法性</p><form onSubmit="return check(this);" name="form1">        <!--表单--><input type="text" name="email">        <!--用户输入email的文本框--><input type="submit" value="确定">        <!--提交按钮--></form>
</center>

总的来说正则表达式其实就是对字符串的一种处理的匹配模式!

"👍点赞" "✍️评论" "收藏❤️"

大家的支持就是我坚持下去的动力!

如果以上内容有任何错误或者不准确的地方,🤗🤗🤗欢迎在下面 👇👇👇 留个言指出、或者你有更好的想法,
欢迎一起交流学习❤️❤️💛💛💚💚

更多 好玩 好用 好看的干货教程可以 点击下方关注❤️ 微信公众号❤️
说不定有意料之外的收获哦..🤗嘿嘿嘿、嘻嘻嘻🤗!
🌽🍓🍎🍍🍉🍇

这篇关于【你也能从零基础学会网站开发】Web建站之javascript入门篇 简单认识一下正则表达式的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


原文地址:
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.chinasem.cn/article/810375

相关文章

Python Web框架Flask、Streamlit、FastAPI示例详解

《PythonWeb框架Flask、Streamlit、FastAPI示例详解》本文对比分析了Flask、Streamlit和FastAPI三大PythonWeb框架:Flask轻量灵活适合传统应用... 目录概述Flask详解Flask简介安装和基础配置核心概念路由和视图模板系统数据库集成实际示例Stre

Spring Bean初始化及@PostConstruc执行顺序示例详解

《SpringBean初始化及@PostConstruc执行顺序示例详解》本文给大家介绍SpringBean初始化及@PostConstruc执行顺序,本文通过实例代码给大家介绍的非常详细,对大家的... 目录1. Bean初始化执行顺序2. 成员变量初始化顺序2.1 普通Java类(非Spring环境)(

Spring Boot 中的默认异常处理机制及执行流程

《SpringBoot中的默认异常处理机制及执行流程》SpringBoot内置BasicErrorController,自动处理异常并生成HTML/JSON响应,支持自定义错误路径、配置及扩展,如... 目录Spring Boot 异常处理机制详解默认错误页面功能自动异常转换机制错误属性配置选项默认错误处理

java如何实现高并发场景下三级缓存的数据一致性

《java如何实现高并发场景下三级缓存的数据一致性》这篇文章主要为大家详细介绍了java如何实现高并发场景下三级缓存的数据一致性,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 下面代码是一个使用Java和Redisson实现的三级缓存服务,主要功能包括:1.缓存结构:本地缓存:使

Java Spring的依赖注入理解及@Autowired用法示例详解

《JavaSpring的依赖注入理解及@Autowired用法示例详解》文章介绍了Spring依赖注入(DI)的概念、三种实现方式(构造器、Setter、字段注入),区分了@Autowired(注入... 目录一、什么是依赖注入(DI)?1. 定义2. 举个例子二、依赖注入的几种方式1. 构造器注入(Con

SpringBoot 异常处理/自定义格式校验的问题实例详解

《SpringBoot异常处理/自定义格式校验的问题实例详解》文章探讨SpringBoot中自定义注解校验问题,区分参数级与类级约束触发的异常类型,建议通过@RestControllerAdvice... 目录1. 问题简要描述2. 异常触发1) 参数级别约束2) 类级别约束3. 异常处理1) 字段级别约束

如何在Java Spring实现异步执行(详细篇)

《如何在JavaSpring实现异步执行(详细篇)》Spring框架通过@Async、Executor等实现异步执行,提升系统性能与响应速度,支持自定义线程池管理并发,本文给大家介绍如何在Sprin... 目录前言1. 使用 @Async 实现异步执行1.1 启用异步执行支持1.2 创建异步方法1.3 调用

java内存泄漏排查过程及解决

《java内存泄漏排查过程及解决》公司某服务内存持续增长,疑似内存泄漏,未触发OOM,排查方法包括检查JVM配置、分析GC执行状态、导出堆内存快照并用IDEAProfiler工具定位大对象及代码... 目录内存泄漏内存问题排查1.查看JVM内存配置2.分析gc是否正常执行3.导出 dump 各种工具分析4.

Spring Boot配置和使用两个数据源的实现步骤

《SpringBoot配置和使用两个数据源的实现步骤》本文详解SpringBoot配置双数据源方法,包含配置文件设置、Bean创建、事务管理器配置及@Qualifier注解使用,强调主数据源标记、代... 目录Spring Boot配置和使用两个数据源技术背景实现步骤1. 配置数据源信息2. 创建数据源Be

Spring Boot 3.x 中 WebClient 示例详解析

《SpringBoot3.x中WebClient示例详解析》SpringBoot3.x中WebClient是响应式HTTP客户端,替代RestTemplate,支持异步非阻塞请求,涵盖GET... 目录Spring Boot 3.x 中 WebClient 全面详解及示例1. WebClient 简介2.