一、正则表达式

1、匹配方法

RegExp

exec

/ab+c/.exec('abbcjhuohuoabcjhih') 
// ["abbc", index: 0, input: "abbcjhuohuoabcjhih", groups: undefined]

test 返回true or false

String方法

match: 当reg没有g的时候和exec一样,当有g的时候直接返回匹配数组
replace
search:返回索引
split

  • 创建正则
// pattern/flags
const regex = /ab+c/;
const regex = /^[a-zA-Z]+[0-9]*\W?_$/gi;

// new RegExp(pattern [, flags])
let regex = new RegExp("ab+c");
let regex = new RegExp(/^[a-zA-Z]+[0-9]*\W?_$/, "gi");  // 斜杠
let regex = new RegExp("^[a-zA-Z]+[0-9]*\\W?_$", "gi"); // 引号,多了转义字符

2、一些符号

  • i不区分大小写
  • g 全局匹配
  • () 匹配
'bar foo'.replace( /(...) (...)/, '$2 $1' )
var reg = /(\w+)\s(\w+)/;
var str = "John Smith";
var newstr = str.replace(reg, "$2, $1");
console.log(newstr); // Smith, John
  • [] [a-z] 任意一个
  • {} {3,4} 表示次数,3到4次;\d{3}连续三个数字
  • \w 数字字母下划线,等价于[A-Za-z0-9_]
  • \W 等价于[^A-Za-z0-9_],匹配 "50%." 中的 %
    当 '^' 作为第一个字符出现在一个字符集合模式时,它将会有不同的含义'%'。大写就是反的。
  • \d 数字
* //0个或以上,等价于{0,}
+ //一个或以上,等价于{1,}
? // 等价于{0,1}
let str = '123abc'
贪婪(尽可能匹配多的字符串):应用 /\d+/ 将会返回 "123"
非贪婪:使用 /\d+?/,那么就只会匹配到 "1"
.(小数点)匹配除换行符之外的任何单个字符

3、零宽断言

(?=exp)  //正先行断言  匹配后缀前的
[a-z]*(?=ing) 匹配 cooking ,singing ,doing中除了ing之外的内容,只取cook, sing, do的内容
(?<=exp) //正后发断言  匹配前缀后的
(?<=abc).* 可以匹配 abcdefgabc 中的 defgabc 而不是 abcdefg
(?!exp)  //反先行断言
(?<!exp) //反后发断言
image.png

4、注意事项

  • \b 匹配一个零宽单词边界(zero-width word boundary),如一个字母与一个空格之间。 (不要和 [\b] 混淆)
    例如,/\bno/ 匹配 "at noon" 中的 "no",/ly\b/ 匹配 "possibly yesterday." 中的 "ly"。
  • ^ 单独出现是开始标志,和字母组合是补集的意思

5、小括号()捕获

  • exec 返回的数组arr[0]完整匹配。后面1234分别匹配1234个括号
  • 1-9
var str = 'hello world';            
var pattern = /([a-z]+)\s([a-z]+)/; 
pattern.test(str); //这个地方必须运行正则匹配一次,方式不限,可以是test()、exec()、以及String的正则方式

console.log(RegExp.$1) //'hello' 第一个分组([a-z]+)的值
console.log(RegExp.$2) //'world' 第二个分组([a-z]+)的值

var n_str = RegExp.$2+' '+RegExp.$1;
console.log(n_str) //world hello

7、非捕获(?: 表达式)

//先看用捕获性分组匹配会返回什么
var str1 = '000aaa111';             
var pattern = /([a-z]+)(\d+)/; //捕获性分组匹配
var arr = pattern.exec(str1);  
console.log(arr) //['aaa111','aaa','111']   结果子串也获取到了,这并不是我们想要的结果

//非捕获性分组
var str2 = '000aaa111';
var pattern2 = /(?:[a-z]+)(?:\d+)/; //非捕获性分组匹配
var arr2 = pattern.exec(str2);  
console.log(arr2) //['aaa111']  结果正确

8、如果正则中有变量,用new来构造

var reg = new RegExp(`${x}`,'g')

实例

1-判断邮箱

reg=/^(\w)+(\.\w+)*@(\w)+(\.\w+)+$/;

2-输入'rgb(255, 255, 255)',输出#ffffff

    return sRGB.replace(/^rgb\((\d+),\s*(\d+),\s*(\d+)\)$/g,function(a,b,c,d){   //a是原字符串,bcd是圆括号匹配到的数字
        return '#'+hex(b)+hex(c)+hex(d);
        function hex(n){
            return n<16? '0'+(+n).toString(16) : (+n).toString(16);  } })

3- -webkit-border-image 转成webkitBorderImage

return sName.replace(/\-[a-z]/g,function(s,i){             //i为每次匹配到的字符
        return i==0? s.replace("-",""): s.replace("-","").toUpperCase();
    });

4-提取数字

var a='(2 -> 4 -> 3)'
b=a.match(/\d/g)
/*是否带有小数*/
function    isDecimal(strValue )  {  
   var  objRegExp= /^\d+\.\d+$/;
   return  objRegExp.test(strValue);  
}  

/*校验是否中文名称组成 */
function ischina(str) {
    var reg=/^[\u4E00-\u9FA5]{2,4}$/;   /*定义验证表达式*/
    return reg.test(str);     /*进行验证*/
}

/*校验是否全由8位数字组成 */
function isStudentNo(str) {
    var reg=/^[0-9]{8}$/;   /*定义验证表达式*/
    return reg.test(str);     /*进行验证*/
}

/*校验电话码格式 */
function isTelCode(str) {
    var reg= /^((0\d{2,3}-\d{7,8})|(1[3584]\d{9}))$/;
    return reg.test(str);
}

/*校验邮件地址是否合法 */
function IsEmail(str) {
    var reg=/^\w+@[a-zA-Z0-9]{2,10}(?:\.[a-z]{2,4}){1,3}$/;
    return reg.test(str);
}
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 217,509评论 6 504
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,806评论 3 394
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 163,875评论 0 354
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,441评论 1 293
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,488评论 6 392
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,365评论 1 302
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,190评论 3 418
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,062评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,500评论 1 314
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,706评论 3 335
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,834评论 1 347
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,559评论 5 345
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,167评论 3 328
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,779评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,912评论 1 269
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,958评论 2 370
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,779评论 2 354

推荐阅读更多精彩内容