好好学一遍JavaScript 笔记(七)

javaScript RegExp对象:html

    global——Boolean值、表示g(全局选项)是否已设置
    ignoreCase——Boolean值、表示i(忽略大小写选项)是否已设置
    lastIndex——整数、表明下次匹配将会从哪一个字符位置开始(只有当使用exec()或test()函数才会填入、不然为0)
    multiline——Boolean值、表示m(多行模式选项)是否已设置
    source——正则表达式的源字符串形式。例如、表达式/[ba]*/的source将返回"[ba]*"。
    通常不会使用global、ignoreCase、multiline和source属性、由于通常以前就已知道了这些数据。
    真正有用的属性是lastIndex、它能够告诉你正则表达式在某个字符串中中止以前、查找了多远。java

  
  
           
  
  
  1. var sToMatch = "bbq is short for barbecue"
  2.         var reB = /b/g; 
  3.         reB.exec(sToMatch);   
  4.         alert(reB.lastIndex);    //out: 1 
  5.         reB.exec(sToMatch);   
  6.         alert(reB.lastIndex);    //out: 2  
  7.         reB.exec(sToMatch);   
  8.         alert(reB.lastIndex);    //out: 18 
  9.         reB.exec(sToMatch);   
  10.         alert(reB.lastIndex);    //out: 21   

正则表达式reB查找的是b。当它首次检测sToMatch时、
它发如今第一个位置——也就是位置0——是b;
所以、lastIndex属性就被设置成一、
而再次调用exec()时就从这个地方开始执行。
再次调用exec()、表达式在位置1又发现了b、
因而将lastIndex设值为2.第三次调用时、发现b在位置1七、
因而又将lastIndex设值为1八、如此继续。
若是想从头开始匹配、则能够将lastIndex设为0。正则表达式

 

静态属性:ide

  
  
           
  
  
  1. /** 
  2.       * 它们都有两个名字:一个复杂名字和一个以美圆符号开头的简短名字。 
  3.       * 长名        短名     描述 
  4.       * input        $_     最后用于匹配的字符串(传递给exec()或test()的字符串) 
  5.       * lastMatch    $&     最后匹配的字符 
  6.       * lastParen    $+     最后匹配的分组 
  7.       * leftContext  $`     在上次匹配的前面的子串 
  8.       * multiline    $*     用于指定是否全部表达式都使用多行模式的布尔值 
  9.       * rightContext $'     在上次匹配以后的子串 
  10.       */ 
  11.      var sToMatch = "古道西风瘦马、夕阳西下、断肠人在天涯!";   
  12.      var reB = /(西)风/g; 
  13.      reB.test(sToMatch); 
  14.      alert(RegExp.$_);  //out:古道西风瘦马、夕阳西下、断肠人在天涯! 
  15.      alert(RegExp.leftContext);  //out:古道  
  16.      /* 
  17.       * 使用短名时有些字符是不合法的须要使用[]  
  18.       * ["$'"] 
  19.       * ["$+"] 
  20.       * ["$&"]   
  21.       * ["$`"] 
  22.       */ 
  23.      alert(RegExp["$'"]);  //out:瘦马、夕阳西下、断肠人在天涯!  

经常使用正则验证——原连接 http://topic.csdn.net/u/20080820/14/dadb903c-8724-422e-a3bd-f2f1c4e812c6.html函数

  
  
           
  
  
  1. ^\d+$  //匹配非负整数(正整数 + 0)  
  2. ^[0-9]*[1-9][0-9]*$  //匹配正整数  
  3. ^((-\d+)|(0+))$  //匹配非正整数(负整数 + 0)  
  4. ^-[0-9]*[1-9][0-9]*$  //匹配负整数  
  5. ^-?\d+$    //匹配整数  
  6. ^\d+(\.\d+)?$  //匹配非负浮点数(正浮点数 + 0)  
  7. ^(([0-9]+\.[0-9]*[1-9][0-9]*)|([0-9]*[1-9][0-9]*\.[0-9]+)|([0-9]*[1-9][0-9]*))$  //匹配正浮点数  
  8. ^((-\d+(\.\d+)?)|(0+(\.0+)?))$  //匹配非正浮点数(负浮点数 + 0)  
  9. ^(-(([0-9]+\.[0-9]*[1-9][0-9]*)|([0-9]*[1-9][0-9]*\.[0-9]+)|([0-9]*[1-9][0-9]*)))$  //匹配负浮点数  
  10. ^(-?\d+)(\.\d+)?$  //匹配浮点数  
  11. ^[A-Za-z]+$  //匹配由26个英文字母组成的字符串  
  12. ^[A-Z]+$  //匹配由26个英文字母的大写组成的字符串  
  13. ^[a-z]+$  //匹配由26个英文字母的小写组成的字符串  
  14. ^[A-Za-z0-9]+$  //匹配由数字和26个英文字母组成的字符串  
  15. ^\w+$  //匹配由数字、26个英文字母或者下划线组成的字符串  
  16. ^[\w-]+(\.[\w-]+)*@[\w-]+(\.[\w-]+)+$    //匹配email地址  
  17. ^[a-zA-z]+://匹配(\w+(-\w+)*)(\.(\w+(-\w+)*))*(\?\S*)?$  //匹配url  
  18. 匹配中文字符的正则表达式: [\u4e00-\u9fa5]  
  19. 匹配双字节字符(包括汉字在内):[^\x00-\xff] 
  20. 应用:计算字符串的长度(一个双字节字符长度计2,ASCII字符计1) 
  21. String.prototype.len=function(){return this.replace([^\x00-\xff]/g,"aa").length;}  
  22. 匹配空行的正则表达式:\n[\s| ]*\r  
  23. 匹配HTML标记的正则表达式:/<(.*)>.*<\/\1>|<(.*) \/>/  
  24. 匹配首尾空格的正则表达式:(^\s*)|(\s*$)
  
  
           
  
  
  1. /* 正则表达式用例
  2. * 一、^\S+[a-z A-Z]$ 不能为空 不能有空格  只能是英文字母 
  3.   * 二、\S{6,}         不能为空 六位以上 
  4.   * 三、^\d+$          不能有空格 不能非数字 
  5.   * 四、(.*)(\.jpg|\.bmp)$ 只能是jpg和bmp格式 
  6.   * 五、^\d{4}\-\d{1,2}-\d{1,2}$ 只能是2004-10-22格式 
  7.   * 六、^0$            至少选一项 
  8.   * 七、^0{2,}$        至少选两项 
  9.   * 八、^[\s|\S]{20,}$ 不能为空 二十字以上 
  10.   * 九、^\+?[a-z0-9](([-+.]|[_]+)?[a-z0-9]+)*@([a-z0-9]+(\.|\-))+[a-z]{2,6}$邮件 
  11.   * 十、\w+([-+.]\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)*([,;]\s*\w+([-+.]\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)*)* 输入多个地址用逗号或空格分隔邮件 
  12.   * 十一、^(\([0-9]+\))?[0-9]{7,8}$电话号码7位或8位或前面有区号例如(022)87341628 
  13.   * 十二、^[a-z A-Z 0-9 _]+@[a-z A-Z 0-9 _]+(\.[a-z A-Z 0-9 _]+)+(\,[a-z A-Z 0-9 _]+@[a-z A-Z 0-9 _]+(\.[a-z A-Z 0-9 _]+)+)*$ 
  14.   *     只能是字母、数字、下划线;必须有@和.同时格式要规范 邮件 
  15.   * 13 ^\w+@\w+(\.\w+)+(\,\w+@\w+(\.\w+)+)*$上面表达式也能够写成这样子,更精练。 
  16.     14   ^\w+((-\w+)|(\.\w+))*\@\w+((\.|-)\w+)*\.\w+$ 

补充:this

  
  
           
  
  
  1. 21。匹配空行的正则表达式:\n[\s| ]*\r 
  2. 21。匹配空行的正则表达式:/^\s*$/m 
  3.  
  4. 22。匹配HTML标记的正则表达式:/<(.*)>.*<\/\1>|<(.*)\/>/ 
  5. 22。匹配HTML标记的正则表达式:/<([^>]+)>[^<>]*<\/\1>|<([^>]+)\/>/ 
  6. 这个实际上做用不大,由于正则表达式不能支持嵌套匹配,仅 .NET 的表达式引擎有这个功能。 
  7.  
  8. 23。匹配首尾空格的正则表达式:(^\s*)|(\s*$) 
  9. 23。匹配首尾空格的正则表达式:^\s+|\s+$ 
  10. 为 JavaScript 的 String 增长 trim() 函数: 
  11. String.prototype.trim = function() { 
  12. return this.replace(/^\s+/, '').replace(/\s+$/, ''); 
  13.  
  14. * 四、(.*)(\.jpg|\.bmp)$ 只能是jpg和bmp格式 
  15. * 四、([^.]+)\.(jpg|bmp) 只能是jpg和bmp格式 
  16.  
  17. * 八、^[\s|\S]{20,}$ 不能为空 二十字以上 
  18. * 八、^\S{20,}$ 不能为空 二十字以上
相关文章
相关标签/搜索