阅读Javascript高级程序设计第五章 -- RegExp类型总结

  对于基础教程部分, 有小伙伴不熟悉的,可以参考 正则表达式 - 教程

  1. 基础部分回顾:

  ECMASript通过RegExp类型来支持正则表达式, 语法如下

var expression = / pattern /flags;

  参数介绍: pattern部分可以是如何简单或复杂的正则表达式,可以包含字符类,限定符,分组,向前查找以及反向引用. 每个正则表达式都可以带一个或多个flags,用以标明正则表达式的行为.

  ⭕️ g: 表示全局模式,即模式将被应用与所有字符串;

  ⭕️ i: 表示不区分大小写模式;

  ⭕️ m: 表示多行模式, 即在到达一行文本末尾时还会继续查找下一行中是否存在与模式匹配的项.

  与其他语言中的正则表达式类似, 模式中使用的所有元字符都必须转移. 正则表达式中都元字符包括

(    [    {    \    ^    &    |    )    ?    *    +    .    ]    }

  举例说明:    

let pattern1 = /at/g; //匹配字符串中所有"at"实例
let pattern2 = /[bc]at/i; // 匹配第一个"bat"或"cat", 不区分大小写
let pattern3 = /\[bc\]at/i; // 匹配第一个"[bc]at", 不区分大小写
let pattern4 = /.at/gi; //匹配所有以"at"结尾的3个字符的组合,不区分大小写
let pattern5 = /\.at/gi; // 匹配所有以".at",不区分大小写

  除以上字面量模式, 正则表达式还常采用构造函数new RegExp(pattern,flags)来定义正则表达式

let reg = new RegExp(pattern,flags);

  两者是等价的

let pattern1 = /[bc]at/i; // 匹配第一个"bat"或"cat", 不区分大小写

等价于
let pattern2 = new RegExp("[bc]at","i");

  备注: 传递个RegExp构造函数的两个参数都是字符串. 由于RegExp构造函数的模式参数是字符串, 所以在某些情况下要对字符串进行双重转义. 因此, 上面列举对元字符都必须进行双重转义.  

  2. RegExp实例属性

  ⭕️ global: 布尔值, 表示是否设置了g标志

  ⭕️ ignoreCase:  布尔值, 表示是否设置了i标志

  ⭕️ lastIndex: 整数, 表示开始搜索下一个匹配项的字符位置,从0算起

  ⭕️ multiline: 布尔值, 表示是否设置了m标志

  ⭕️ source: 正则表达式字符串表示,按照字面量形式而非传人构造函数中的字符串模式返回

  举例说明实例属性各个性质

let p1 = /\[bc\]at/g;
let p2 = new RegExp("\\[bc\\]at","g");
console.log(p1.global); // true
console.log(p1.ignoreCase); // false
console.log(p1.lastIndex); //
console.log(p1.multiline); // false
console.log(p1.source); // "\[bc\]at"
console.log(p2.source); // "\[bc\]at"

  3 正则表达式实例方法

  3.1 RegExp对象的主要方法之一是exec()  

  3.2

  4 RegExp 构造函数属性

  RegExp构造函数包含一些属性( 这些属性在其他语言中被看成是静态属性 ). 这些属性适用于作用域中所有的正则表达式,并且基于所执行的最近一次正则表达式操作而变化, 这些属性有一个长属性名和短属性名. 列表如下

  举例说明

let str = "this is number of wuhan i love you yyhan";
let reg = /(.)han/g;
if(reg.test(str)){
console.log(RegExp.input);
console.log(RegExp.$1);
console.log(RegExp.lastMatch);
console.log(RegExp.lastParen);
console.log(RegExp.leftContext);
console.log(RegExp.rightContext);
console.log(RegExp.multiline);
console.log(RegExp.name);
} console.log("写法 **********上 等价 下***********"); if(reg.test(str)){
console.log(RegExp.$_);
console.log(RegExp.$1);
console.log(RegExp["$&"]);
console.log(RegExp["$+"]);
console.log(RegExp["$`"]);
console.log(RegExp["$'"]);
console.log(RegExp["$*"]);
console.log(RegExp.name);
}

  打印结果

this is number of wuhan i love you yyhan
u
uhan
u
this is number of w
i love you yyhan
undefined
RegExp
写法 **********上 等价 下***********
this is number of wuhan i love you yyhan
y
yhan
y
this is number of wuhan i love you y
undefined
RegExp

  

    

最新文章

  1. RequireJS学习笔记
  2. 【iPhone手机老提示升级怎么办】
  3. 分布式系统一致性问题和Raft一致性算法
  4. 【poj 3461】Oulipo(字符串--KMP)
  5. linux--基础学习笔记--软件安装
  6. 100个常用的linux命令
  7. 第11条:理解objc_msgSend的作用
  8. Linux下一个C(编程入门.h档,.c档,而路多文件的调用)
  9. SpringMVC提供两种校验机制
  10. mysql 数据插入时的问题
  11. java static语句的总结
  12. poj 1759(二分)
  13. python2和3使用pip时的问题
  14. redis 五大数据类型以及操作
  15. 【转】MVC5学习笔记 BindAttribute
  16. 手机app有了短信验证码还有没必要有图片验证码?
  17. openwrt设置默认登陆密码
  18. 【BZOJ1041】圆上的整点(数论)
  19. 从实例中学习grid布局
  20. 安装Ubuntu之后的配置

热门文章

  1. ZROI 暑期高端峰会2019 总结
  2. 计时任务之StopWatch
  3. 编译安装php-fpm5.6 (centos 7)
  4. 推荐一款移动端小视频App声咖视频
  5. Linux内核定时器struct timer_list
  6. laravel框架中Job和事件event的解析
  7. linux内核树的建立(Ubuntu)
  8. 2018 ACM-ICPC徐州站网络赛 G题
  9. kali 安装 360国产浏览器
  10. spring-retry 重试机制的使用