正则: 它就是一种规则,用来处理字符串的规则,这说明了正则就是用来处理字符串的。
处理:
-
匹配: 判断一个字符串是否符合我们制定的规则 -> test() ->
reg.test(str);
var reg = /\d/; // -> 包含一个0-9之间的数字
console.log(reg.test("derrick")); // -> false
console.log(reg.test("1")); // -> true
console.log(reg.test("derrick20")); // -> true
- **捕获: **把字符串中符合正则规则的内容捕获到 -> exec() ->
reg.exec(str);
var reg = /\d/; // -> 包含一个0-9之间的数字
console.log(reg.exec("derrick")); // -> null
console.log(reg.exec("1")); // -> ["1", index: 0, input: "1]
如何创建一个正则?
字面量方式:
var reg = /\d/;
实例创建方式:
var reg = new RegExp("\d");
正则的两种创建方式是有区别的:
在字面量方式中,在//之间包起来的所有的内容都是元字符,有的具有特殊的意义,大部分都是代表本身含义的普通的元字符。
var name = "derrick";
var reg = /^\d+"+name+"\d+$/;
console.log(reg.test("20derrick20")); // -> false
console.log(reg.test('20""name"555')); // -> true
对于需要进行字符串拼接的需求,只能使用实例创建的方式了。
var reg = new RegExp("^\\d+" + name + "\\d+$");
console.log(reg.test("20derrick20")); // -> true
console.log(reg.test('20""name"555')); // -> false
所以,字面量方式和实例创建的方式在正则中的区别如下:
- 字面量方式中出现的一切都是元字符,所以不能进行变量值的拼接,而实例创建的方式是可以的。
- 字面量方式中直接写\d就可以了,而在实例创建的方式中,需要把其转义 -> \d。