码迷,mamicode.com
首页 > 编程语言 > 详细

JavaScript之正则表达式初识

时间:2015-04-10 17:56:44      阅读:134      评论:0      收藏:0      [点我收藏+]

标签:正则表达式   javascript   

1、什么是正则表达式

正则表达式(Regular Expression)是一个描述字符模式的对象,ECMAcript的RegExp类表示正则表达式,而String和RegExp都定义了使用正则表达式强大的模式匹配和文本检索与替换的函数。

2、创建正则表达式的方式

第一种创建方式

		var box=new RegExp('box');           //第一个是参数字符串
		var box=new RegExp('box','ig')     //第二个是可选模式修饰符
第二种创建方式

		var box=/box/;    //直接用反斜杠
<span style="white-space:pre">		</span>var box=/box/ig;  //在第二个反斜杠后面加上模式修饰符
技术分享

 3、测试正则表达式

RegExp对象包含两个方法:test()和exec()用于测试字符串匹配。

test()
te
st()方法在字符串中查找是否存在指定的正则表达式并返回布尔值,如果存在则返回true。不存在则返回false.
exec()
也用于在字符串中查找正则表达式,如果exec()方法执行成功,则返回包含该查找字符串的相关信息,如果失败,则返回null.

		/*使用new运算符的test方法示例*/
		var pattern=new RegExp('box','i');        //创建正则表达式,不区分大小写
		var str="This is a Box!";                          //创建要比对的字符串
		alert(pattern.test(str));                          //通过test()方法验证是否匹配
		
		/*使用字面量方式的test方法示例*/  
		var pattern=/box/i;                                //创建正则表达式,不区分大小写
		var str="This is a Box!";
		alert(pattern.test(str));
		
		/*使用exec返回匹配数组*/
		var pattern=/box/i;
		var str="This is a Box!";
		alert(pattern.exec(str));                          //匹配了返回数组,否则返回null

使用字符串的正则表达式的方法

技术分享

4、获取控制

正则表达式元字符是包含特殊含义的字符。它们有一些特殊功能,可以控制匹配模式的方式,反斜杠后的元字符将失去其特殊含义。

贪婪与懒惰

贪婪模式与懒惰模式的语法区别在于重复限定修饰符的后面是否有问号,有的话就是懒惰模式,否则就是贪婪模式。
贪婪量词,是先吃尽所有字符,然后再一个一个地吐出来,直到匹配成功为止。

懒惰量词,是从头开始一个字符一个字符地吃,直到匹配成功为止。即贪婪是逐渐向前匹配,而懒惰是向后慢慢匹配。

例子:

<span style="white-space:pre">	</span>var pattern=/[a-z]+?/		//?关闭了贪婪匹配,只替换了第一个
<span style="white-space:pre">	</span>var str='ajfifdjnfasdfdasdgh';
<span style="white-space:pre">	</span>var result=str.replace(pattern,'xxx');
<span style="white-space:pre">	</span>alert(result);		//返回xxxjfifdjnfasdfdasdgh
<span style="white-space:pre">	</span><pre name="code" class="javascript"><span style="white-space:pre">	</span>var pattern=/8(.+?)8/g;  //禁止了贪婪,开启的全局
<span style="white-space:pre">	</span>var str='this is 8abc8, that is 8abc8, there is 8abc8';
<span style="white-space:pre">	</span>var result=str.replace(pattern,'<strong>$1</strong>');
 <span style="white-space:pre">	</span>document.write(result);		//返回this is abc, that is abc, there is abc


总结:

个人认为,通过正则表达式在客户端进行验证,可以减轻到服务器端后再验证对服务器的压力。对正则表达式的认识还只是粗浅的认识。在以后还需要不断的实践来完善。

JavaScript之正则表达式初识

标签:正则表达式   javascript   

原文地址:http://blog.csdn.net/mascf/article/details/44981451

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!