JavaScript中的正则表达式操作

来源:互联网 发布:电脑桌面图标美化软件 编辑:程序博客网 时间:2024/06/05 15:33
总是搞混RegExp对象的方法和字符串正则方法,整理备忘一下,抄自JavaScript权威指南 
Javascript代码  收藏代码
  1. var reg = new RegExp("[a-zA-Z]+""gi");// 或者  
  2. var rex  = /[a-zA-Z]+/gim;  


RegExp对象方法 
1. exec(string) 
返回:返回单个匹配,和详细信息 
Javascript代码  收藏代码
  1. var pattern = /Java/g;  
  2. var text = "JavaScript is mor fun than Java!";  
  3. var result = pattern.exec(text);  
  4. while(result != null){  
  5.     console.log("match "+result[0]+" start at "+result.index+", end at "+pattern.lastIndex);  
  6.     result = pattern.exec(text);  
  7. }  


2. test(string) 
返回:如果字符串中含有匹配正则表达式的字符串,那么返回true,如果不包含,那么返回false 
Javascript代码  收藏代码
  1. var reg = /java/i;  
  2. console.log(reg.test("welcome to JavaScript"));  
  3. // 加上^和$限定就可以用来判定整个字符串是否符合正则表达式  
  4. console.log(/^\s*$/.test(""));  
  5. console.log(/^\s*$/.test(" 1"));  
  6. console.log(/^\s*$/.test("1 "));  
  7. console.log(/^\s*$/.test(" 1 "));  
  8. console.log(/^\s*$/.test("1 1"));  



字符串对象方法
 
1. search(regexp) 
返回:第一个匹配的位置,或者-1 
举例: 
Javascript代码  收藏代码
  1. "JavaScript".search(/script/i); // return 4  

search不支持“g”标记,会直接忽略 

2. replace(regexp, "replacement"); 
返回: 替换后的字符串 
举例:
Javascript代码  收藏代码
  1. "Javascript is javascript".replace(/javascript/gi, "JavaScript");  


如果没有设置"g"标记,那么只替换第一个匹配的字符串,如果设置了"g"标记,那么会替换所有匹配到的字符串 
Javascript代码  收藏代码
  1. "Javascript is not javascript".replace(/javascript/i, "JavaScript"); // "JavaScript is not javascript"  


可以使用反向引用已匹配到的字符串,如 
Javascript代码  收藏代码
  1. "var a=1234;".replace(/([a-z]+)=(\d+)/gi, "$1 = $2");// 轻松补上空格  


3. match(regexp) 
返回:正则表达式匹配的字符串列表 
Javascript代码  收藏代码
  1. "1 + 2 = 3".match(/\d+/g);// ["1", "2", "3"]  

如果设置了g标记,那么返回字符串中所有的匹配 
如果没有设置g标记,那么只查找第一个匹配,但是返回结果依然是一个列表,list[0]包含匹配的整个字符串, list[1]...list[n]包含第n个分组 
Javascript代码  收藏代码
  1. var url = /(\w+):\/\/([\w.]+)\/(\S*)/;  
  2. var text = "visit http://www.google.com/codeSearch";  
  3. var list = text.match(url);  
  4. if(list != null){  
  5.     console.log(list[0]);  
  6.     console.log(list[1]);  
  7.     console.log(list[2]);  
  8.     console.log(list[3]);  
  9. }  

4. split(regexp) <-- 还支持参数为字符串 
返回:根据正则表达式分割后的字符串列表