JS正则

    技术2022-07-10  106

    JS 中的正则用法一般是有两种,一是新建RegExp对象,进行正则匹配;二是直接在字符串对象的函数中使用,如:string.match(), string.split().

    RegExp

    直接用字面量生成RegExp对象:/^\w+$/i

    采用构造函数: let reg = new RegExp(’^\w+KaTeX parse error: Undefined control sequence: \w at position 41: …= new RegEXp(/^\̲w̲+/,‘i’)

    常用函数:

    test() 方法执行一个检索,用来查看正则表达式与指定的字符串是否匹配。返回true或false

    regObj.test(str)

    exec()方法在一个指定字符串中执行一个搜索匹配。返回一个结果数组或null。

    返回值:如果匹配成功,exec() 方法返回一个数组,并更新正则表达式对象的属性。返回的数组将完全匹配成功的文本作为第一项,将正则括号里匹配成功的作为数组填充到后面。如果匹配失败,exec() 方法返回null。
    regObj.exec(str)

    @@match() 方法会返回一个数组,它包括整个匹配结果,和通过捕获组匹配到的结果,如果没有匹配到则返回null

    下面这两个的结果是一样的。
    'abc'.match(/a/); /a/[Symbol.match]('abc');

    @@replace]() 方法会在一个字符串中用给定的替换器,替换所有符合正则模式的匹配项,并返回替换后的新字符串结果。用来替换的参数可以是一个字符串或是一个针对每次匹配的回调函数。

    下面这两个的结果是一样的。
    'abc'.replace(/a/, 'A'); /a/[Symbol.replace]('abc', 'A');

    @@search]() 方法执行了一个在给定字符串中的一个搜索以取得匹配正则模式的项。

    返回值:整数如果成功的话,@@search]() 返回该正则模式的第一个匹配项的在字符串中的位置索引。否则将返回-1
    'abc'.search(/a/); /a/[Symbol.search]('abc');

    @@split]() 方法切割String对象为一个其子字符串的数组

    参数 str切割操作的目标字符串 ,limit可选。一个为了限制切割数量的特定整数。 @@split]() 防范仍会切割每个匹配正则模式的匹配项,直到切割数量达到该限制数,除非提前切割完字符串。
    'a-b-c'.split(/-/); /-/[Symbol.split]('a-b-c');

    常用语法

    修饰符

    i 执行对大小写不敏感的匹配。 g 执行全局匹配(查找所有匹配而非在找到第一个匹配后停止)。 m 执行多行匹配。

    方括号

    [abc] 查找方括号之间的任何字符。 [^abc] 查找任何不在方括号之间的字符。 [0-9] 查找任何从 09 的数字。 [a-z] 查找任何从小写 a 到小写 z 的字符。 [A-Z] 查找任何从大写 A 到大写 Z 的字符。 [A-z] 查找任何从大写 A 到小写 z 的字符。 [adgk] 查找给定集合内的任何字符。 [^adgk] 查找给定集合外的任何字符。 (red|blue|green) 查找任何指定的选项。

    元字符

    . 查找单个字符,除了换行和行结束符。 \w 查找单词字符。单词字符指的是(英文字母和数字以及下划线) \W 查找非单词字符。 \d 查找数字。 \D 查找非数字字符。 \s 查找空白字符。 \S 查找非空白字符。 \b 匹配单词边界。 \B 匹配非单词边界。 \0 查找 NUL 字符。 \n 查找换行符。 \f 查找换页符。 \r 查找回车符。 \t 查找制表符。 \v 查找垂直制表符。 \xxx 查找以八进制数 xxx 规定的字符。 \xdd 查找以十六进制数 dd 规定的字符。 \uxxxx 查找以十六进制数 xxxx 规定的 Unicode 字符。

    量词

    n+ 匹配任何包含至少一个 n 的字符串。 n* 匹配任何包含零个或多个 n 的字符串。 n? 匹配任何包含零个或一个 n 的字符串。 n{X} 匹配包含 X 个 n 的序列的字符串。 n{X,Y} 匹配包含 XY 个 n 的序列的字符串。 n{X,} 匹配包含至少 X 个 n 的序列的字符串。 n$ 匹配任何结尾为 n 的字符串。 ^n 匹配任何开头为 n 的字符串。 ?=n 匹配任何其后紧接指定字符串 n 的字符串。 ?!n 匹配任何其后没有紧接指定字符串 n 的字符串。

    其他

    正则表达式中的小括号”()”。是代表分组的意思。 如果再其后面出现\1则是代表与第一个小括号中要匹配的内容相同

    参考:

    https://www.w3school.com.cn/jsref/jsref_obj_regexp.asp

    https://cloud.tencent.com/developer/section/1192048

    Processed: 0.067, SQL: 9