在上一篇中介绍了一个test方法,在本文中将使用另外一个,exec方法可以找到匹配的结果并且返回结果以及位置。exec("正则");
简单测试:
var str = "{追梦子}";var reg = /追梦子/;console.log(reg.exec(str)); //["追梦子", index: 1, input: "{追梦子}"]
exec返回的是一个数组,第一位是匹配到的内容,第二位是匹配到的内容第一位置的索引,索引从0开始的。
另外如果需要匹配一段文本,并且把某一个字提取出来可以给需要提取出来的子加括号。
var str = "{追梦子}";var reg = /追(梦)子/;console.log(reg.exec(str)); //["追梦子", "梦", index: 1, input: "{追梦子}"]
也有人叫它分组,更多exec的用途会在后面的几节中详细讲到,因为我们需要更多的知识来扩充我们的大脑。
.字符可以用来匹配任意的一个字符串。
var str = "#f3f3f3";var reg = /./;console.log(reg.exec(str)); //["#", index: 0, input: "#f3f3f3"]
小任务:我们需要匹配var str = "json.js";这段文本,并且.js前面可以是任意的内容,温馨提示+可以匹配任何包含至少一个n的字符串。
var str = "json.js";var reg = /.+\.js/;console.log(reg.exec(str)); //["json.js", index: 0, input: "json.js"]
如果使用了正则表达式中的特殊字符最好前面加\进行转译。所谓特殊字符就是某个字符在正则中有特殊的含义,比如+、. 、*、?等。
假如我们想提取.js前面的字符可以这样做。
var str = "json.js";var reg = /(.+)\.js/;console.log(reg.exec(str)); //index.js:3 ["json.js", "json", index: 0, input: "json.js"]
回想一下我们前面说的分组,当然我们也可以使用多个分组。
var str = "json.js";var reg = /(.+)\.(js)/;console.log(reg.exec(str)); //["json.js", "json", "js", index: 0, input: "json.js"]
至于这有什么用后面会讲的,不用着急。
^表示这个字符后面的那个字符必须出现在开始的位置。
var str = "wjson.js";var reg = /^j.+\.(js)/;console.log(reg.exec(str)); //null
因为j并不在开始的位置
var str = "json.js";var reg = /^j.+\.(js)/;console.log(reg.exec(str)); //["json.js", "js", index: 0, input: "json.js"]
^还有另外一个用途,如果在[]中使用^那么^表示的就是取非。
var str = "jQuery.js";var reg = /j[^a-z][a-z]*.js/;console.log(reg.exec(str)); //["jQuery.js", index: 0, input: "jQuery.js"]
[^a-z]表示除了小写a-z以外的任意字符,另外这段代码还使用了*号,*号表示匹配前面一个字符零次或者多次。在这里就是匹配[a-z]中的任意一个字符0次或多次。
本节完。