网站建设资讯

NEWS

网站建设资讯

怎样快速学习正则表达式

这篇文章给大家分享的是有关怎样快速学习正则表达式的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。

创新互联长期为1000多家客户提供的网站建设服务,团队从业经验10年,关注不同地域、不同群体,并针对不同对象提供差异化的产品和服务;打造开放共赢平台,与合作伙伴共同营造健康的互联网生态环境。为涞源企业提供专业的网站设计制作、成都网站制作涞源网站改版等技术服务。拥有十载丰富建站经验和众多成功案例,为您定制开发。

正则表达式概念

正则表达式,又称正规表示法、常规表示法(英语:Regular Expression,在代码中常简写为regex、regexp或RE),计算机科学的一个概念。正则表达式使用单个字符串来描述、匹配一系列符合某个句法规则的字符串。在很多文本编辑器里,正则表达式通常被用来检索、替换那些符合某个模式的文本。

在日常工作中,我们经常写正则表达式,比如在表单中经常用来验证用户输入的格式是否正确,我们就会用到正则表达式;可以把正则表达式看做是可以描述问题的语言,它就是专门为模式匹配而设计的

-------------------------------------------------------------------------------

正则表达式的语法

可以简单粗暴得把正则表达式理解为查找东西,举个例子:要在"Hello World"中找到"world"这个单词,先用直白的语言来描述就是查找"从w开头到d结束的字母组合",使用正则来描述就是\bw\w*d\b,这个就是模式字符串,它由元字符和字面量字符组成

•常见的元字符如下:

怎样快速学习正则表达式

•正则表达式中的旗标

怎样快速学习正则表达式

•正则表达式中的转义字符

怎样快速学习正则表达式

JS中的正则表达式

•两种生成方式,

举例:匹配0-9有没有出现

复制代码 代码如下:


1、通过RegExp var reg=new RegExp('^[0-9]','g');
2、通过表达式字面量 var reg=/^[0-9]/g;

•两种常用的方法

test()、exec()

复制代码 代码如下:


1、test方法:如果输入字符串与模式相匹配,test就返回真,没有则返回假
2、exec方法:如果输入字符串与模式匹配,则返回一个数组,没有匹配就返回null

/*test()方法,匹配是否有出现0-9*/
var reg1=/^[0-9]/;
reg1.test('There is no number');
//返回结果为false
/*exec()方法,匹配句子里面的单词,两个单词一组*/
/*没有设置全局旗标*/
var reg2=/(\w+)\s(\w+)/;
reg2.test('There is no number');
//返回结果['There is','There','is']
//第0个元素是匹配的字符串,后面两个元素分别是分组引用的子字符串
/*设置全局旗标*/
var reg3=/(\w+)\s(\w+)/g;
reg3.test('There is no number');
//设置了全局旗标的话,exec()会循环寻找
//第一次查找结果['There is','There','is'],第二次结果['no number','no','number'],第三次结果null 
exec()方法如果设置了全局旗标,在循环中使用必须要手动设置其reg.lastIndex = 0;,否则它会间隔匹配

--------------------------------------------------------------------------------

字符串对象与正则表达式

•在string对象中有不少以正则表达式对象作为参数的方法

属性说明
match(regexp)返回正则表达式regexp的匹配结果
replace(searchValue,replaceValue)将searchValue(正则表达式或是字符串值)
 替换为replaceValue,并返回响应的字符串
search(regexp)返回正则表达式regexp匹配位置的下标,没有匹配就返回-1
split(separator,limit)通过参数separator(字符串或是正则表达式)
 对字符串进行分割,并返回一个字符串数组

•match方法会返回元素与模式相匹配的字符串的数组,设置全局旗标时,会返回所有与模式相匹配的字符串数组,不设置时和exec方法相同

应用例子:

var text='abc def ghi jkl';
//设置全局旗标
text.match(/\w+/g);
//["abc","def","ghi","jkl"]
//不设置全局旗标
text.match(/(\w+)\s(\w+)/);
//["abc def","abc","def"] •replace方法返回被替换的字符串,如果设置了全局旗标,则替换全部匹配了的字符串,否则只替换第一个匹配的字符串;replace中如果第一个参数用了分组,第二个参数能够通过符号来标识分组的前向引用

怎样快速学习正则表达式

应用例子:

var text="abc def ghi jkl";
//将空格替换为字符
text.replace(/\s/,',');
//"abc,def ghi jkl"
text.replace(/\s/g,',');
//"abc,def,ghi,jkl"
//对空格之前的字符分组,用逗号替换并前向移动一位
text.replace(/(.)\s/g,",$1");
//"ab,cde,fgh,igkl" •在search与split方法中,正则表达式的全局旗标不起作用

感谢各位的阅读!关于“怎样快速学习正则表达式”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,让大家可以学到更多知识,如果觉得文章不错,可以把它分享出去让更多的人看到吧!


网站名称:怎样快速学习正则表达式
本文来源:http://njwzjz.com/article/pgdsjs.html