javascript RegExp 使用说明


Posted in Javascript onMay 21, 2016

一:正则表达式的创建方式  
 1.文字格式,使用方法如下: 
 /pattern/flags(即:/模式/标记) 
 2.RegExp构造函数,使用方法如下: 
 new RegExp("pattern"[,"flags"])(即:new RegExp("模式"[,"标记"])) 
  
 参数: 
 pattern(模式):表示正则表达式的文本 
 flags(标记):如果指定此项,flags可以是下面之一: 
  
 g:global match(全定匹配) 
 i:ignore case(忽略大小写) 
 gi:both global match and ignore case(匹配所有可能的值,也忽略大小写) 
 注意:文字格式中的参数不要使用引号标记,二够造器函数的参数则要使用引号标记。所以下面的表达式 
 是等价的: 
 /ab+c/i     ====================  new RegExp("ab+c","i") 
  
 描述: 
 当使用构造器函数创建正则表达式的时候,必须使用正常的字符串避开规则(在字符串中加入前导字符\)是必须的。 
 例如,下面的两条语句是等价的:  
 re=new RegExp("\\w+"); 
 re=/\w+/ 

注意:RegExp预置了$属性
$1, ..., $9属性
用圆括号括着的匹配子串,如果有的话。
是RegExp的属性
静态,只读
在JavaScript 1.2, NES 3.0以上版本提供
描述:因为input是静态属性,不是个别正则表达式对象的属性。你可以使用RegExp.input 访问该
属性。
能加上圆括号的子串的数量不受限制,但正则表达式对象只能保留最后9 条。如果你要访问所有的
圆括号内的匹配字串,你可以使用返回的数组。

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN"> 
 <HTML> 
 <HEAD> 
  <TITLE> New Document </TITLE> 
  <SCRIPT LANGUAGE="JavaScript1.2"> 
  var regexp = new RegExp("(\\w+)\\s(\\w+)"); 
 str = "John Smith"; 
 newstr=str.replace(regexp,"$2"); 
 newstr2=str.replace(regexp,"$1"); 
 document.write("原字符串:"+str+"<br/>"); 
 document.write(newstr+"<br/>"); 
 document.write(newstr2+"<br/>"); 
 document.write('$1='+RegExp.$1+"  $2="+RegExp.$2); 
 </SCRIPT> 
 </HEAD> 
 <BODY> 
 </BODY> 
 </HTML>

二: match() 方法可在字符串内检索指定的值,或找到一个或多个正则表达式的匹配。它返回指定的值,而不是字符串的位置。

语法
stringObject.match(searchvalue)
stringObject.match(regexp)参数 描述
searchvalue 必需。规定要检索的字符串值。
regexp 必需。规定要匹配的模式的 RegExp 对象。如果该参数不是 RegExp 对象,则需要首先把它传递给 RegExp 构造函数,将其转换为 RegExp 对象。
返回值
存放匹配结果的数组。该数组的内容依赖于 regexp 是否具有全局标志 g。
说明
match() 方法将检索字符串 stringObject,以找到一个或多个与 regexp 匹配的文本。这个方法的行为在很大程度上有赖于 regexp 是否具有标志 g。

如果 regexp 没有标志 g,那么 match() 方法就只能在 stringObject 中执行一次匹配。如果没有找到任何匹配的文本, match() 将返回 null。否则,它将返回一个数组,其中存放了与它找到的匹配文本有关的信息。

match使用实例:

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN"> 
 <HTML> 
 <HEAD> 
  <TITLE> New Document </TITLE> 
  <SCRIPT LANGUAGE="JavaScript1.2"> 
 var str="1 plus 2 equal 3"; 
 var str2="11/23/55"; 
 var results=str.match(new RegExp("\\d+","gi")); 
 for(var i=0;i<results.length;i++){ 
   document.write(results[i]+"<br/>"); 
 } 
 var res=str2.match(new RegExp("(\\d\\d?)/(\\d\\d?)/(\\d\\d)")); 
 if(str2.length == res[0].length){ 
   document.write(res[1]+"<br/>"); 
   document.write(res[2]+"<br/>"); 
   document.write(res[3]+"<br/>"); 
 } 
 </SCRIPT> 
 </HEAD> 
 <BODY> 
 </BODY> 
 </HTML> 
  
 function dateCheck(value) { 
   re = new RegExp("(\\d\\d?)/(\\d\\d?)/(\\d\\d)"); 
   var result = value.match (re); 
   if (result){ 
     if (result[0].length != value.length){ 
       alert ("Wrong date format. The correct format should be MM/dd/yy.") 
       return false; 
     }else{ 
       var t = result[3]; 
       var y = parseInt("20" + t); 
       var m = parseInt(result[1], 10) - 1; 
       var day = parseInt(result[2], 10); 
  
       var d = new Date(y, m, day); 
       if (d.getFullYear() != y || d.getMonth() != m || d.getDate() != day){ 
         alert ("error date!") 
         return false; 
       }else{ 
         var sm = result[1].length == 1?'0' + result[1]:result[1]; 
         var sday = result[2].length == 1?'0' + result[2]: result[2]; 
         var sy = result[3]; 
         else  
           return sm + '/' + sday + '/' + sy; 
       } 
     } 
   }else{ 
     alert ("Wrong date format. The correct format should be MM/dd/yy."); 
     return false; 
   } 
 }
Javascript 相关文章推荐
关于JavaScript的一些看法
May 27 Javascript
jQuery-ui中自动完成实现方法
Jun 10 Javascript
addEventListener和attachEvent二者绑定的执行函数中的this不相同
Dec 09 Javascript
JavaScript起点(严格模式深度了解)
Jan 28 Javascript
jQuery中[attribute]选择器用法实例
Dec 31 Javascript
JavaScript常用脚本汇总(二)
Mar 04 Javascript
JavaScript判断字符长度、数字、Email、电话等常用判断函数分享
Apr 01 Javascript
php+ajax+jquery实现点击加载更多内容
May 03 Javascript
getElementById().innerHTML与getElementById().value的区别
Oct 27 Javascript
angular分页指令操作
Jan 09 Javascript
vue-router实现嵌套路由的讲解
Jan 19 Javascript
微信小程序获取当前时间及星期几的实例代码
Sep 20 Javascript
js+html5实现canvas绘制椭圆形图案的方法
May 21 #Javascript
jQuery DataTables插件自定义Ajax分页实例解析
Apr 28 #Javascript
Markdown+Bootstrap图片自适应属性详解
May 21 #Javascript
使用jQuery实现WordPress中的Ctrl+Enter和@评论回复
May 21 #Javascript
JavaScript的ExtJS框架中数面板TreePanel的使用实例解析
May 21 #Javascript
IScroll5 中文API参数说明和调用方法
May 21 #Javascript
JavaScript的ExtJS框架中表格的编写教程
May 21 #Javascript
You might like
深入eAccelerator与memcached的区别详解
2013/06/06 PHP
使用phpstorm和xdebug实现远程调试的方法
2015/12/29 PHP
解决yii2左侧菜单子级无法高亮问题的方法
2016/05/08 PHP
解决laravel 出现ajax请求419(unknown status)的问题
2019/09/03 PHP
发一个自己用JS写的实用看图工具实现代码
2008/07/26 Javascript
jQuery处理xml格式的返回数据(实例解析)
2013/11/28 Javascript
Javascript封装DOMContentLoaded事件实例
2014/06/12 Javascript
javascript单例模式的简单实现方法
2015/07/25 Javascript
BootStrap 智能表单实战系列(二)BootStrap支持的类型简介
2016/06/13 Javascript
微信小程序 天气预报开发实例代码源码
2017/01/20 Javascript
js中的面向对象入门
2017/03/06 Javascript
springMVC + easyui + $.ajaxFileUpload实现文件上传注意事项
2017/04/23 Javascript
纯js封装的ajax功能函数与用法示例
2018/05/14 Javascript
vue中使用v-for时为什么不能用index作为key
2020/04/04 Javascript
Python读取文件内容的三种常用方式及效率比较
2017/10/07 Python
Python语言描述连续子数组的最大和
2018/01/04 Python
numpy.random.seed()的使用实例解析
2018/02/03 Python
使用Numpy读取CSV文件,并进行行列删除的操作方法
2018/07/04 Python
Python3.6.2调用ffmpeg的方法
2019/01/10 Python
python全栈知识点总结
2019/07/01 Python
Python编程快速上手——疯狂填词程序实现方法分析
2020/02/29 Python
Python3爬虫中关于Ajax分析方法的总结
2020/07/10 Python
python3处理word文档实例分析
2020/12/01 Python
python实现图片转字符画的完整代码
2021/02/21 Python
eBay比利时购物网站:eBay.be
2019/08/09 全球购物
市场营销专业推荐信
2013/11/03 职场文书
长安大学毕业生自我鉴定
2014/01/17 职场文书
交通安全寄语大全
2014/04/08 职场文书
教师个人自我评价范文
2014/04/13 职场文书
2014乡镇干部纪律作风整顿思想汇报
2014/09/13 职场文书
销售简历自我评价怎么写
2014/09/26 职场文书
2016元旦晚会主持词
2015/07/01 职场文书
2016元旦晚会主持人开场白和结束语
2015/12/03 职场文书
优秀员工演讲稿
2019/06/21 职场文书
农村房屋租赁合同(范本)
2019/07/23 职场文书
学会用Python实现滑雪小游戏,再也不用去北海道啦
2021/05/20 Python