zoukankan      html  css  js  c++  java
  • JS邮箱验证-正则验证

      1 <form action="">
      2   输入:<input type="text" name="mazey" id="mazey" placeholder="请输入邮箱">
      3   <input type="button" value="验证" onclick="check();">
      4 </form>
      5 
      6 <script>
      7 function check(){
      8   var reg = new RegExp("^[a-z0-9]+([._\-]*[a-z0-9])*@([a-z0-9]+[-a-z0-9]*[a-z0-9]+.){1,63}[a-z0-9]+$"); //正则表达式
      9   var obj = document.getElementById("mazey"); //要验证的对象
     10   if(obj.value === ""){ //输入不能为空
     11     alert("输入不能为空!");
     12     return false;
     13   }else if(!reg.test(obj.value)){ //正则验证不通过,格式不对
     14     alert("验证不通过!");
     15     return false;
     16   }else{
     17     alert("通过!");
     18     return true;
     19   }
     20 }
     21 </script>
     22 
     23 一、RegExp
     24 
     25 1.1 创建RegExp对象
     26 
     27 new RegExp("必选,正则表达式","可选,匹配模式g,i,m")
     28 1.2 RegExp对象的方法
     29 
     30 test:检索字符串中的指定值,返回True或False。
     31 exec:检索字符串中的指定值,返回找到的值,没有则null。
     32 complie:用于改变正则表达式,或增删匹配模式。
     33 1.2.1 test()
     34 
     35 var r1 = new RegExp('world');
     36 console.log(r1.test('Hello, world!')); //true
     37 console.log(r1.test('Hello, World!')); //false
     38 var r2 = new RegExp('world', 'i'); //大小写不敏感
     39 console.log(r2.test('Hello, World!')); //true
     40 var r3 = new RegExp(/world/i); //简写
     41 console.log(r3.test('Hello, World!')); //true
     42 1.2.2 exec()
     43 
     44 var r1 = new RegExp('world');
     45 console.log(r1.exec('Hello, world!')); //['world']
     46 console.log(r1.exec('Hello, World!')); //null
     47 var r2 = new RegExp('world', 'i'); //大小写不敏感
     48 console.log(r2.exec('Hello, World!')); //['world']
     49 var r3 = new RegExp(/world/i); //简写
     50 console.log(r3.exec('Hello, World!')); //['world']
     51 var r4 = new RegExp('o');
     52 console.log(r4.exec('Hello, World!')); //['o']
     53 var r5 = new RegExp('o', 'gi');
     54 console.log(r5.exec('Hello, WOrld!')); //['o']
     55 console.log(r5.lastIndex); //5 匹配文本的第一个字符的位置,o为4,下一个位置为5
     56 console.log(r5.exec('Hello, WOrld!')); //['O'] 匹配完第一个o后调用继续匹配
     57 console.log(r5.lastIndex); //9
     58 console.log(r5.exec('Hello, WOrld!')); //null 匹配不到返回null
     59 console.log(r5.lastIndex); //0 lastIndex重置为0
     60 1.2.3 complie()
     61 
     62 var r1 = new RegExp('world');
     63 console.log(r1.exec('Hello, world!')); //['world']
     64 r1.compile('o');
     65 console.log(r1.exec('Hello, World!')); //['o']
     66 r1.compile('m');
     67 console.log(r1.exec('Hello, World!')); //null
     68 var r2 = new RegExp('world');
     69 console.log(r2.test('Hello, world!')); //true
     70 r2.compile('mazey');
     71 console.log(r2.test('Hello, world!')); //false
     72 二、正则表达式
     73 
     74 ^$:表示匹配值的开始和结尾。
     75 +:1+,一个或更多。
     76 *:0+,零个或更多。
     77 ?:0/1,零个或一个。
     78 {1,2}:1<=length<=2,长度。
     79 ():表示一个表达式的组。
     80 []:匹配的字符范围,我理解为一个块,很多块放在一个组()里面。
     81 三、示例
     82 
     83 <form action="">
     84 输入:<input type="text" name="mazey" id="mazey" placeholder="请输入邮箱">
     85 <input type="button" value="验证" onclick="check();">
     86 </form>
     87 <script>
     88 function check(){
     89     var reg = new RegExp("^[a-z0-9]+([._\-]*[a-z0-9])*@([a-z0-9]+[-a-z0-9]*[a-z0-9]+.){1,63}[a-z0-9]+$"); //正则表达式
     90     var obj = document.getElementById("mazey"); //要验证的对象
     91     if(obj.value === ""){ //输入不能为空
     92         alert("输入不能为空!");
     93         return false;
     94     }else if(!reg.test(obj.value)){ //正则验证不通过,格式不对
     95         alert("验证不通过!");
     96         return false;
     97     }else{
     98         alert("通过!");
     99         return true;
    100     }
    101 }
    102 </script>
  • 相关阅读:
    Android 使用ViewPager结合PhotoView开源组件实现网络图片在线浏览功能
    Android教程 -06 Activity的生命周期
    Android教程 -05 Android6.0权限的管理
    Android 设置ImageView宽度固定,其高度按比例缩放适应
    一技压身,天下行走
    解析P2P金融的业务安全
    Android Listview中Button按钮点击事件冲突解决办法
    Android 动态设置TextView的drawableLeft等属性
    Android教程 -04 启动其它Activity,静态工厂设计模式传递数据
    瞬息之间与时间之门
  • 原文地址:https://www.cnblogs.com/chenlinlab/p/10915019.html
Copyright © 2011-2022 走看看