1. RegExp.test(String)
测试string中是否包含有匹配结果,返回true(包含)或false(不包含)
// 检测字符串中是否有中文
var reg = /([\u4E00-\u9FA5\uF900-\uFA2D])/g;
// 匹配到,返回true
var str1 = reg.test( "彭2牛是渣渣");
console.log(str1); // true
// 匹配不到,返回false
var str2 = reg.test("6666");
console.log(str2); // false
2. String.match(RegExp)
根据pattern进行正则匹配,如果匹配到,返回匹配结果,如匹配不到返回null
var reg = /([\u4E00-\u9FA5\uF900-\uFA2D])/g;
// 匹配到,返回匹配到的结果
var str = "彭2牛是渣渣".match(reg);
console.log(str); // ["彭", "牛", "是", "渣", "渣"];
// 匹配不到,返回null
var str1 = "666".match(reg);
console.log(str1); // null
3. String.search(RegExp)
根据pattern进行正则匹配,如果匹配到一个结果,则返回它的索引数;否则返回-1
var reg = /([\u4E00-\u9FA5\uF900-\uFA2D])/g;
// 匹配到,返回匹配到的索引
var index = "彭2牛是渣渣".search(reg);
console.log(index ); // 0
// 匹配不到,返回-1
var index1 = "666".search(reg);
console.log(index1); // -1
4. String.replace([RegExp | String], [String | Function])
根据pattern进行正则匹配,把匹配结果替换为replacement
// 如果第二个参数是字符串,则$符号具有特殊的意义,$n表示匹配到的第n个字符,js先提取RegExp匹配出的结果,然后用第二个参数逐一替换匹配出的结果
var reg = /彭大/g;
var str = "彭大牛牛牛牛".replace(reg,"**");
console.log(str); // **牛牛牛牛
// 如果第二个参数是一个函数,每匹配到一个结果就回调一次,每次回调都会传递以下参数:
// result: 本次匹配到的结果
// $1,...$9: 正则表达式中有几个子表达式(),就会传递几个参数
// offset: 记录本次匹配的开始位置
// source: 接受匹配的原始字符串
var tel = '18812341234';
var str1 = tel.replace(/(\d{3})(\d{4})(\d{4})/,function (rs,$1,$2,$3){
return $1+" "+$2+" "+$3
});
5. RegExp .exec(String)
exec对string进行正则处理,并返回匹配结果。除了返回匹配到的字符串外,还返回了子表达式匹配到的值,index(匹配到的文本所处的索引)和input(原字符串的值)
var reg = /([\u4E00-\u9FA5\uF900-\uFA2D]+)是渣渣/g;
var arr = reg.exec("666彭大牛是渣渣");
console.log(arr); // ["彭大牛是渣渣", "彭大牛", index: 3, input: "666彭大牛是渣渣"],第一个值"彭大牛是渣渣"是匹配到的字符串,第二个值"彭大牛"是第一个子表达式匹配到的值,3(index)是匹配到的文本所在的索引,input是原字符串的值。
6. String.split(RegExp )
根据pattern进行正则分割,返回一个分割的数组
var str = 'http://www.baidu.com/';
var reg = /\W/;
var ret = str.split(reg);
console.log(ret); //["http", "", "", "www", "baidu", "com", ""]
7.常用正则表达式
// 校验金额
/(^[1-9]([0-9]+)?(\.[0-9]{1,2})?$)|(^(0){1}$)|(^[0-9]\.[0-9]([0-9])?$)/