正则表达式

创建正则表达式

//字面量创建
var Reg = /box/gi;
//构造函数创建
var Reg = new RegExp("box","gi");

字符串中的正则表达式方法

  • String.match(Reg) 返回RegExp匹配的包含全部字符串的数组或null
  • String.search(Reg) 返回RegExp匹配字符串首次出现的位置
  • String.replace(Reg, newStr) 用newStr替换RegExp匹配结果,并返回新字符串
  • String.split(Reg) 返回字符串按指定RegExp拆分的数组
var str = 'a1b2c3a4a5',
    reg = /a/g;
console.log(str.match(reg)); //["a", "a", "a"]

var str = 'a1b2c3a4a5',
    reg = /a/;
console.log(str.search(reg)); //0

var str = 'a1b2c3a4a5',
    reg = /a/g;
console.log(str.replace(reg,function(){
    console.log(arguments);
    return 5555;
}));

var str = 'a,b,c,d',
    reg = /,/g;
//console.log(str.split(',')); //["a", "b", "c", "d"]
console.log(str.split(reg)) //["a", "b", "c", "d"]

RegExp对象的方法

  • RegExp.exec(String) 在字符串中执行匹配搜索,返回首次匹配结果数组
  • RegExp.test(String) 在字符串中测试模式匹配,返回true或false

var str = 'abcd',
    reg = /\w/g;
console.log(reg.exec(str)); //["a", index: 0, input: "abcd", groups: undefined]
console.log(reg.exec(str)); //["b", index: 1, input: "abcd", groups: undefined]
console.log(reg.exec(str)); //["c", index: 2, input: "abcd", groups: undefined]
console.log(reg.exec(str)); //["d", index: 3, input: "abcd", groups: undefined]
console.log(reg.exec(str)); //null
console.log(reg.exec(str)); //["a", index: 0, input: "abcd", groups: undefined]

var str = 'abcd',
    reg = /7/g;
console.log(reg.test(str)); //false

修饰符

修饰符也称作标识符,可指定匹配的模式,修饰符用于执行区分大小写和全局匹配。

  • i忽略大小写匹配。
  • g全局匹配,没有g只匹配第一个元素,就不在进行匹配。
  • m执行多行匹配。
var patt =  /pattern/i;         //忽略大小写匹配
var patt =  /pattern/g;         //全局匹配
var patt =  /pattern/m;         //执行多行匹配

元字符

在正则表达式中具有特殊意义的专用字符。
特殊的转译字符. \ /

  • . 单个任意字符,除了换行符\n与制表符\r
  • \ 转义字符,将具有特殊意义的符号转义成普通符号: .
  • \d 数字[0~9]
  • \D 非数字
  • \s 空格
  • \S 非空格
  • \w 字符[字母|数字|下划线]
  • \W 非字符
  • \b 单词边界( 除了 (字)字母 数字_ 都算单词边界)
  • \B 非单词边界
var reg = /\./;//匹配.
var reg = /\\/;//匹配\
var reg = /\//;//匹配/

var str = '\\';
var reg = /\\/g;
console.log(reg.test(str)); //true

量词

匹配字符的出现次数,匹配模式中有贪婪模式与懒惰模式。
量词 默认就是贪婪模式。

  • n? 可有可无,匹配0个或1个n的字符串
  • n* 匹配0个或多个字符串(任意个)
  • n+ 匹配至少1个n字符串
  • n{num} 匹配包含num个n的序列的字符串
  • n{min,max} 匹配包含至少min或至多max个n的序列的字符串
  • n{num,} 匹配至少num个n的序列字符串

特殊符号

  • ^n 匹配以n开头的字符串
  • n$ 匹配以n结尾的字符串
  • [^n] ^出现中在[]中括号里表示取不包含n字符的字符串
  • n|m 匹配n或者m.两个只取一个

贪婪/懒惰

贪婪: 尽可能多的匹配 / 惰性: 尽可能少的匹配。

  • n+ 贪婪模式为默认
  • n+? 量词后面带?问号就是懒惰模式,以次类推
  • {n,m} 贪婪模式
  • {n,m}? 懒惰模式
var reg = /好{3}/;//查找出现3次的字符
var reg = /好{0,9}/;//匹配一个字符出现9次的,不行的话就递减 9 8 7 6 5 4 3 2 1 0(贪婪模式)
var reg = /好{1,9}/;//匹配一个字符出现1~9次的 先最大次数开始匹配(贪婪模式)
var reg = /好{1,}/;//最少出现一次,最多没有上限
var reg = /好{1,2}/;//最少出现一次,最多两次
var reg = /好*/;// 匹配0个或任意个字符串(任意个) {0,}
var reg = /好+/;//只是一个最多没有上限{1,}
var reg = /好?/;//可有可无 可以是没有也可以是1个 {0,1}

var reg = /好{3,9}/;//贪婪模式 往多的找
var reg = /好{2,9}?/;//惰性(懒惰)模式 往少的找
var reg = /好{2,9}?/g;//全局匹配

var reg = /^l\w+/gm;//查找l开头的任意字符
var reg = /\w+2$/gm;//任意字符后面是以2结束的字符

字集[]/分组()

字集[],[]代表一个集合。

  • [1-9] 匹配0~9之间的字符
  • [^1-9] 匹配非0~9之间的字符
  • [a-z] 匹配小写a至小写z的字符
  • [A-Z] 匹配大写A至大写Z的字符
  • [\u4e00-\u9fa5] 匹配所有中文
  • [1-9a-zA-Z] 可配合使用

分组(),()代表一个分组。

(abc)b 匹配到abcd字符串abc是一个不可划分的整体
(\d{4})b 匹配任意4个数字加上b的字符

匹配到的分组可以依次使用 12 $3取到。

var y = "2018-06-29";
y.replace(/(d+)-(d+)-(d+)/,"$2/$3/$1");//"06/29/2018"

var str = 'abcdefg';
var reg = /(abc)d/;//匹配abcd
var val = reg.exec( str);
console.log( val );   //["abcd", "abc", index: 0, input: "abcdefg"]
//索引0 为匹配的结果,索引1 为第一个子表达式 匹配结果 ,index :首次匹配成功的索引值, input: 匹配目标。
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

友情链接更多精彩内容