【你也能从零基础学会网站开发】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

相关文章

Java实现在Word文档中添加文本水印和图片水印的操作指南

《Java实现在Word文档中添加文本水印和图片水印的操作指南》在当今数字时代,文档的自动化处理与安全防护变得尤为重要,无论是为了保护版权、推广品牌,还是为了在文档中加入特定的标识,为Word文档添加... 目录引言Spire.Doc for Java:高效Word文档处理的利器代码实战:使用Java为Wo

SpringBoot日志级别与日志分组详解

《SpringBoot日志级别与日志分组详解》文章介绍了日志级别(ALL至OFF)及其作用,说明SpringBoot默认日志级别为INFO,可通过application.properties调整全局或... 目录日志级别1、级别内容2、调整日志级别调整默认日志级别调整指定类的日志级别项目开发过程中,利用日志

Java中的抽象类与abstract 关键字使用详解

《Java中的抽象类与abstract关键字使用详解》:本文主要介绍Java中的抽象类与abstract关键字使用详解,本文通过实例代码给大家介绍的非常详细,感兴趣的朋友跟随小编一起看看吧... 目录一、抽象类的概念二、使用 abstract2.1 修饰类 => 抽象类2.2 修饰方法 => 抽象方法,没有

SpringBoot 多环境开发实战(从配置、管理与控制)

《SpringBoot多环境开发实战(从配置、管理与控制)》本文详解SpringBoot多环境配置,涵盖单文件YAML、多文件模式、MavenProfile分组及激活策略,通过优先级控制灵活切换环境... 目录一、多环境开发基础(单文件 YAML 版)(一)配置原理与优势(二)实操示例二、多环境开发多文件版

Spring 中的切面与事务结合使用完整示例

《Spring中的切面与事务结合使用完整示例》本文给大家介绍Spring中的切面与事务结合使用完整示例,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考... 目录 一、前置知识:Spring AOP 与 事务的关系 事务本质上就是一个“切面”二、核心组件三、完

使用docker搭建嵌入式Linux开发环境

《使用docker搭建嵌入式Linux开发环境》本文主要介绍了使用docker搭建嵌入式Linux开发环境,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面... 目录1、前言2、安装docker3、编写容器管理脚本4、创建容器1、前言在日常开发全志、rk等不同

Java实现远程执行Shell指令

《Java实现远程执行Shell指令》文章介绍使用JSch在SpringBoot项目中实现远程Shell操作,涵盖环境配置、依赖引入及工具类编写,详解分号和双与号执行多指令的区别... 目录软硬件环境说明编写执行Shell指令的工具类总结jsch(Java Secure Channel)是SSH2的一个纯J

JavaScript中比较两个数组是否有相同元素(交集)的三种常用方法

《JavaScript中比较两个数组是否有相同元素(交集)的三种常用方法》:本文主要介绍JavaScript中比较两个数组是否有相同元素(交集)的三种常用方法,每种方法结合实例代码给大家介绍的非常... 目录引言:为什么"相等"判断如此重要?方法1:使用some()+includes()(适合小数组)方法2

SpringBoot 获取请求参数的常用注解及用法

《SpringBoot获取请求参数的常用注解及用法》SpringBoot通过@RequestParam、@PathVariable等注解支持从HTTP请求中获取参数,涵盖查询、路径、请求体、头、C... 目录SpringBoot 提供了多种注解来方便地从 HTTP 请求中获取参数以下是主要的注解及其用法:1

HTTP 与 SpringBoot 参数提交与接收协议方式

《HTTP与SpringBoot参数提交与接收协议方式》HTTP参数提交方式包括URL查询、表单、JSON/XML、路径变量、头部、Cookie、GraphQL、WebSocket和SSE,依据... 目录HTTP 协议支持多种参数提交方式,主要取决于请求方法(Method)和内容类型(Content-Ty