js高级正则解析

1.var reg=/./   var reg=/\./

前者代表任意一个字符而后者代表这个字符串中得有一个.

2.?的使用

如果单独的一个字符后面带? var reg=/\d?/ /n?/

代表一个或0个这个字符的出现

如果是量词+和*,{2,}后面带? 取消正则的贪婪性  在捕获阶段

 var reg=/\d+?/;
 var st="ahfuoi6565232";
 console.log(reg.exec(st));

3.捕获

1.普通捕获 exec() match()

普通捕获有懒惰性,给正则添加一个修饰符g可以解决,match是将所有捕获的内容放在一个数组中并返回。Match就是对exec的一个简单封装。

2.分组捕获 捕获的方法还是exec 和match

正则在结构上发生了变化,加()

Var reg=/(a)(b)/

Exec()和match()在非全局下分组捕获是相同的,在捕获的过程中即捕获大正则里的内容也捕获分组中的内容并都返回。

 var reg=/(a)(b)/
 var st="ab"
 console.log(reg.exec(st))
 console.log(st.match(reg))

Exec()和match()在全局下的分组捕获是不一样的,exec()不变。但是match()只捕获大正则里的内容

 var reg=/(a)(b)/g
 var st="ab"
 console.log(reg.exec(st))
 console.log(st.match(reg))

  1. 分组捕获的优势
  2. 可以提升优先级
  3. 可以捕获引用

\1代表分组1里面的内容  \2代表分组2里面的内容

前提是分组必须在引用之前,如果\2在分组的前面代表普通的表达式???

分组的结果存在正则类RegExp的$number属性下。

\1 和RegExp.$1 二者都是分组引用

\1只能使用在正则表达式里面,RegExp.$1 可以外面使用。都是在捕获完成的条件下。

  1. 在捕获的过程中怎样取消捕获分组中的内

在分组的前面加上?:就ok了

?:和?=的区别

?:取消捕获分组中的内容的

?=  a(?=s)

 var reg=/a(?=b)/
 var st="ad"
 console.log(reg.exec(st))

4.replace细说

Replace是字符串的一个方法,他有两个参数,用后者将前者替换掉,并返回一个新的字符串,但是没有改变原来的字符串.

  1. 如果第一个参数是字符串,只改变一次
  2. 如果第一个参数是正则,捕获一次改变一次
  3. 如果第二个参数是匿名函数,每捕获一次这个匿名函数会执行一次,return的是什么,那就替换成什么。这个匿名函数的arguments有三个元素。

var str='双十一是奥托的活动';
var reg=/双十一/g;
var ss=str.replace(reg,function(word){
  var w=word;
  var re=/./g;  
  var st=w.replace(re,"face")
  return st;
})
console.log(ss)

转载于:https://www.cnblogs.com/mo123/p/10145340.html

你可能感兴趣的:(js高级正则解析)