正则表达式

\d,\w,\s,[a-zA-Z0-9],\b,.,*,+,?,x{3},^$分别是什么?

\d是查找数字(digital), 数字0~9会被匹配到 。
\w是查找单词(word),字母、下划线、数字都会被匹配到。
\s是查找空格(space),空格会被匹配到。
[a-zA-Z0-9]查找单个在此范围内的字符,此例大小写字母和数字都会被匹配到,非全局。
\b是指词边界(border),可以用两个\b将要匹配的字符包裹。
.是指代任意字符除了回车、换行和分隔符,使用后类似模糊匹配。
*是指匹配0个或多个,类似{0,};
+是指匹配1个或多个,类似{1,}
?是指匹配0个或1个,类似{0,1}
x{3}是指匹配含3个x的字符,就是xxx。
^是指定整个字符串以哪个字符开头。
$是指定整个字符串以哪个字符结尾。

贪婪模式和非贪婪模式

  • 贪婪模式是指匹配时按最大可能去匹配,直到下一个字符不满足条件为止;
  • 非贪婪模式是指匹配时按最小满足条件去匹配,只要满足条件后就不再匹配。

小练习

函数trim(str),去除字符串两边的空白字符

  function trim(str){
    return str.replace(/^\s+|\s+$/g,'');
  }
  var str=" dddff sad dfd ";
  str=trim(str);
  console.log(str);  //"dddff sad dfd"

使用正则实现 addClass(el, cls)、hasClass(el, cls)、removeClass(el,cls)

  // el为dom元素,cls为操作的class, el.className获取el元素的class**
  function hasClass(el, cls){
    var regex=new RegExp('\\b'+cls+'\\b','g');
    return regex.test(el.className);
  }
  function addClass(el, cls){
    if(hasClass(el,cls)===false){
      el.className += " "+cls;
    }
  }
  function removeClass(el,cls){
    if(hasClass(el,cls)===true){
      var regex=new RegExp('\\b'+cls+'\\b','g');
      el.className=el.className.replace(regex,"");
      el.className=el.className.replace(/\s{2}/g," ");
    }
  }
  var el={className:"clear btn foot"};
  hasClass(el,'foot');    // true
  hasClass(el,'header');  //  false
  addClass(el, 'foot');   //  "clear btn foot"
  addClass(el, 'header');  // "clear btn foot header"
  removeClass(el,'btn');  //  "clear foot header"
  removeClass(el,'hatt'); //  "clear foot header"

函数isEmail(str),判断用户输入的是不是邮箱

  function isEmail(str){
    return (/^[a-zA-Z0-9]\w+@\w+\.\w+/.test(str));
  }

函数isPhoneNum(str),判断用户输入的是不是手机号

function isPhoneNum(str){
  return (/^1[3-8]\d{9}$/.test(str));
  }

函数isValidUsername(str),判断用户输入的是不是合法的用户名(长度6-20个字符,只能包括字母、数字、下划线)*

  function isValidUsername(str){
    return (/^\w{6,20}$/.test(str));
  }

函数isValidPassword(str), 判断用户输入的是不是合法密码(长度6-20个字符,包括大写字母、小写字母、数字、下划线至少两种)

function isValidPassword(str){
  var i=0;
  if(/^\w{6,20}$/.test(str)){
    if(/[a-z]/.test(str)){
      i++;
    };
    if(/[A-Z]/.test(str)){
      i++
    };
    if(/[0-9]/.test(str)){
      i++
    };
    if(/_/.test(str)){
      i++
    };
    if(i>1){
      return true;
    }else return false;;
  }else return false;
}

写一个正则表达式,得到如下字符串里所有的颜色(#121212)

var re = /#\b[a-fA-F0-9]{3}\b|#\b[a-fA-F0-9]{6}\b/g;
var subj = "color: #121212; background-color: #AA00ef; width: 12px; bad-colors: f#fddee #fd2 ";
alert( subj.match(re) ) ; // ["#121212", "#AA00ef", "#fd2"]

下面代码输出什么? 为什么? 改写代码,让其输出hunger, world.

var str = 'hello  "hunger" , hello "world"';
var pat =  /".*"/g;
str.match(pat);    //  [""hunger" , hello "world""] 因为使用'*'默认是最大可能匹配 也即贪婪模式
//代码修改如下
var str = 'hello  "hunger" , hello "world"';
var pat =  /".*?"/g;
str.match(pat);     // 使用'?'让其变成非贪婪模式

补全如下正则表达式,输出字符串中的注释内容. (贪婪模式和非贪婪模式两种方法)

    // 非贪婪模式
    str = '.. <!-- My -- comment \n test --> ..  <!----> .. '
    re = /<!--[\W\w]*?-->/g;
    console.log(str.match(re)) // '<!-- My -- comment \n test -->', '<!---->'

    // 贪婪模式
    str = '.. <!-- My -- comment \n test --> ..  <!----> .. '
    re = /<!--[^>]*-->/g;
    console.log(str.match(re)) // '<!-- My -- comment \n test -->', '<!---->'

找出字符串中有效的标签

    var re = /<[^>]+>/g;
    var str = '<> <a href="/"> <input type="radio" checked> <b>'
    console.log(str.match(re)); // '<a href="/">', '<input type="radio" checked>', '<b>'
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,884评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,755评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,369评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,799评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,910评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,096评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,159评论 3 411
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,917评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,360评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,673评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,814评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,509评论 4 334
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,156评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,882评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,123评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,641评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,728评论 2 351

推荐阅读更多精彩内容