js中的正则表达式总结

* 正则表达式:也叫规则表达式,按照一定的规则组成的一个表达式,这个表达式的作用主要是匹配字符串的,
* "我的电话:10086,他的电话:10010,你的电话:10000" 正则表达式,把这个字符串中的所有的数字找到
*
* 正则表达式的作用:匹配字符串的
*
* 在大多数编程语言中都可以使用
*
* 正则表达式的组成:是由元字符或者是限定符组成的一个式子
*
*
* 元字符:
*
* .  表示的是:除了\n以外的任意的一个字符   "fdsfs238"
*
* [] 表示的是:范围,  [0-9] 表示的是0到9之间的任意的一个数字,  "789" [0-9]
* [1-7] 表示的是1到7之间的任意的一个数字
* [a-z] 表示的是:所有的小写的字母中的任意的一个
* [A-Z] 表示的是:所有的大写的字母中的任意的一个
* [a-zA-Z] 表示的是:所有的字母的任意的一个
* [0-9a-zA-Z] 表示的是: 所有的数字或者是字母中的一个
* [] 另一个函数: 把正则表达式中元字符的意义干掉    [.] 就是一个.
* | 或者     [0-9]|[a-z] 表示的是要么是一个数字,要么是一个小写的字母
* () 分组 提升优先级   [0-9]|([a-z])|[A-Z]
* ([0-9])([1-5])([a-z]) 三组, 从最左边开始计算
* (()(()))
*
*
* 都是元字符,但是也可以叫限定符,下面的这些
*    *   表示的是:前面的表达式出现了0次到多次
*    [a-z][0-9]* 小写字母中的任意一个 后面是要么是没有数字的,要么是多个数字的
*    "fdsfs3223323"  [a-z][0-9]*
*
*    +  表示的是:前面的表达式出现了1次到多次
*    [a-z][9]+  小写字母一个后面最少一个9,或者多个9
*    "fesfewww9fefds"
*
*    ?  表示的是:前面的表达式出现了0次到1次,最少是0次,最多1次 ,另一个含义:阻止贪婪模式
*    [4][a-z]? "1231234ij"
*  限定符:限定前面的表达式出现的次数
*  {} 更加的明确前面的表达式出现的次数
*  {0,} 表示的是前面的表达式出现了0次到多次,和 *一样的
*  {1,} 表示的是前面的表达式出现了1次到多次,和 +一样的
*  {0,1} 表示的是前面的表达式出现了0次到1次,和 ?一样的
*  {5,10} 表示的是前面的表达式出现了5次到10次
*  {4} 前面的表达式出现了4次
*  {,10} 错误的========不能这么写
*  ^ 表示的是以什么开始,或者是取非(取反) ^[0-9] 以数字开头
*  ^[a-z] 以小写字母开始
*  [^0-9] 取反,非数字
*  [^a-z] 非小写字母
*  [^0-9a-zA-Z_]
*  $ 表示的是以什么结束   [0-9][a-z]$  必须以小写字母结束
*  ^[0-9][a-z] 相当于是严格模式   "3f2432e"  "4f"
*   \d 数字中的任意一个,
*   \D 非数字中的一个
*   \s 空白符中的一个
*   \S 非空白符
*   \w 非特殊符号
*   \W 特殊符号
*   \b 单词的边界
*   "what are you no sha lei"
*    . 除了\n以外的任意一个单个字符
*    []  范围
*    () 分组,提升优先级
*    | 或者
*    * 0-多次
*    + 1-多次
*    ? 0-1次
*    {0,} 和*一样
*    {1,} 和+
*    {0,1} 和?
*
*    \d 数字中的一个
*    \D 非数字
*    \s 空白符
*    \S 非空白符
*     \W  特殊符号
*     \w 非特殊符号 _
*     ^ 取反,以什么开始
*     $ 以什么结束
*     \b 单词边界

=============================================================
创建正则表达式的方式:
//创建正则表达式对象
1.通过构造函数创建对象
2.字面量的方式创建对象

  • 正则表达式的作用:匹配字符串的
 //对象创建完毕---
 var reg=new RegExp(/\d{5}/);
 //调用方法验证字符串是否匹配
 var flag=reg.test("我的电话是10086");
 console.log(flag);


//字面量的方式创建正则表达式对象
var reg=/\d{1,5}/;
var flag=reg.test("小苏的幸运数字:888");
console.log(flag);

=============================================================
案例验证密码的强度:

  //获取文本框注册键盘抬起事件
 my$("pwd").onkeyup = function() {
//每次键盘抬起都要获取文本框中的内容,验证文本框中有什么东西,得到一个级别,然后下面的div显示对应的颜色
//如果密码的长度是小于6的,没有必要判断
if(this.value.length >= 6) {
    var lvl = getLvl(this.value);
    my$("strengthLevel").className = "strengthLv" + lvl;
} else {
    my$("strengthLevel").className = "strengthLv0";
}
//三元表达式
//my$("strengthLevel").className="strengthLv"+ 
        (this.value.length>=6?getLvl(this.value) :0);
};

 //给我密码,我返回对应的级别
         function getLvl(pwd) {
var lvl = 0; //默认是0级
//密码中是否有数字,或者是字母,或者是特殊符号
if(/[0-9]/.test(pwd)) {
    lvl++;
}
//判断密码中有没有字母
if(/[a-zA-Z]/.test(pwd)) {
    lvl++;
}
//判断密码中有没有特殊符号
if(/[^0-9a-zA-Z_]/.test(pwd)) {
    lvl++;
}
return lvl; //最小的值是1,最大值是3;
  • 密码: 数字,字母,特殊符号
    • 密码: 只有数字- 或者是只有字母,或者是只有特殊符号---1级---弱

    • 两两组合: 数字和字母, 数字和特殊符号, 字母和特殊符号 -----2级----中

    • 三者都有: 数字和字母和特殊符号------3级-----强
      =========================================================
      表单验证:
      html:

      <div class="container" id="dv">
      <label for="qq">Q Q</label><input type="text" id="qq"><span>
      </span>

      <label>手机</label><input type="text" id="phone"><span></span>

      <label>邮箱</label><input type="text" id="e-mail"><span></span>

      <label>座机</label><input type="text" id="telephone"><span></span>

      <label>姓名</label><input type="text" id="fullName"><span></span>

      </div>

  //qq的
 checkInput(my$("qq"),/^\d{5,11}$/);
 //手机
 checkInput(my$("phone"),/^\d{11}$/);
 //邮箱
checkInput(my$("e-mail"),/^[0-9a-zA-Z_.-]+[@][0-9a-zA-Z_.-]+([.][a-zA- 
 Z]+){1,2}$/);
//座机号码
 checkInput(my$("telephone"),/^\d{3,4}[-]\d{7,8}$/);
 //中文名字
 checkInput(my$("fullName"),/^[\u4e00-\u9fa5]{2,6}$/);
//给我文本框,给我这个文本框相应的正则表达式,我把结果显示出来
//通过正则表达式验证当前的文本框是否匹配并显示结果
 function checkInput(input,reg) {
//文本框注册失去焦点的事件
input.onblur=function () {
  if(reg.test(this.value)){
    this.nextElementSibling.innerText="正确了";
    this.nextElementSibling.style.color="green";
  }else{
    this.nextElementSibling.innerText="让你得瑟,错了吧";
    this.nextElementSibling.style.color="red";
  }
}}

==============================================================

//正则表达式中:g 表示的是全局模式匹配
//正则表达式中:i 表示的是忽略大小写

        var str = "中国移动:10086,中国联通:10010,中国电信:10000";
        //把里面所有的数字全部显示出来
        var array = str.match(/\d{5}/g); //正则表达式中:g 表示的是全局模式匹配
        console.log(array);

        var str = "123123@xx.com,fangfang@valuedopinions.cn 286669312@qq.com 2、emailenglish@emailenglish.englishtown.com 286669312@qq.com...";
        var array = str.match(/\w+@\w+\.\w+(\.\w+)?/g);
        console.log(array);

        //提取这里的日
        var str = "2017-11-12";
        var array = str.match(/(\d{4})[-](\d{2})[-](\d{2})/g);
        //console.log(array);
        //正则表达式对象.$3
        console.log(RegExp.$3); //12

        var email = "shuaiyangtaishuaile@itcast.com.cn";
        email.match(/([0-9a-zA-Z_.-]+)[@]([0-9a-zA-Z_-]+)(([.][a-zA-Z]+){1,2})/);
        console.log(RegExp.$1); //用户名
        console.log(RegExp.$2); //126
        console.log(RegExp.$3); //域名

        //replace方法:
        var str = "小苏好帅哦,真的是太帅了,帅,就是真帅";
        str = str.replace(/帅/g, "猥琐");
        console.log(str); //小苏好猥琐哦,真的是太猥琐了,猥琐,就是真猥琐

        //trim()方法
        var str = "  哦买噶的    ,太幸福了  ";
        str = str.trim();
        console.log("===" + str + "==="); //===哦买噶的    ,太幸福了===

        var str = "  哦买噶的    ,太幸福了  ";
        str = str.replace(/\s+/g, "");
        console.log("===" + str + "==="); //===哦买噶的,太幸福了===

        //所有的h都替换成S
        var str = "HhpphH"; //SSppSS
        str = str.replace(/[h]/gi, "S");
        console.log(str); //SSppSS

        //正则
        var reg = new RegExp(/[h]/gi);
        var str = "HhpphH"; //SSppSS
        str = str.replace(reg, "S");
        console.log(str);

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

推荐阅读更多精彩内容

  • python的re模块--细说正则表达式 可能是东半球最详细最全面的re教程,翻译自官方文档,因为官方文档写的是真...
    立而人阅读 22,873评论 4 46
  • 初衷:看了很多视频、文章,最后却通通忘记了,别人的知识依旧是别人的,自己却什么都没获得。此系列文章旨在加深自己的印...
    DCbryant阅读 4,006评论 0 20
  • 每天随手拍,留住瞬间的美好~加倍美好!我们来啦! 本周主题——【食物】尽量多一些当地特色。水果、甜点、零食、一日三...
    水若_小水呓梦阅读 166评论 0 2
  • java的I/O是建立在流(stream)之上的,而流是同步的,当线程请求一个流读/写一段数据时,线程会一直阻塞下...
    慕容小伟阅读 687评论 0 0
  • 资金流动: 行情显示,大盘在6月10日和6月11日破位下跌后继续回落,6月12日反弹较小,没有改变当前市场整体回落...
    币值投顾局阅读 237评论 0 0