JS中的match和test正则表达式验证密码或用户名的一种规则

match语法:
字符串.match(正则表达式)
有符合的:返回符合的数组
无符合的:返回null

test语法:
正则表达式.test(字符串)
有符合的:返回true
无符合的 :返回false

该文的密码或用户名格式:
格式1:
描述:以英文字母开头,在6位到20位之间的以字母数字下划线组成的。
正则1描述:以英文字母开头,后面至少5位的字母数字下划线组合,后面的不能多于19位。
格式2:
在以上基础上允许中间有短线字符。

按左到右顺序描述:第一个位是必须是个字母,后面可有若干位字母数字下划线组合,后面至少有5位,加上前面的第一位字母,整个字符串至少有6位。后面至多有19位,加上前面的第一位的字母,整个字符串至多有20位。

一般常见网站上的用户名(用户账号,虽然昵称可以是中文,但是账号名一般都是这种规则,防止重名),有可能就是这种规则。

测试代码 :

<a href="javascript:prn_p1()">点击获取</a><br>
<script language="javascript" type="text/javascript">   
        var LODOP; //声明为全局变量 
  function prn_p1(){
     console.log("a".match(/a/));//返回数组
     console.log(/a/.test("a"));//返回true
     console.log("b".match(/a/));//返回null
     console.log(/a/.test("b"));//返回false
 
//密码测试1:以字母开头,只能是字母数字下划线,总长度大于或等于6位,小于或等于20位    
 console.log("a1234的5位结果:"+/^[a-zA-Z]\w{5,19}$/.test("a1234"));//5位,位数不符合
 console.log("a12345的6位结果:"+/^[a-zA-Z]\w{5,19}$/.test("a12345"));//6位
 //前面的开头的字母占一位,后面的则需要至少有5位,才能总长度达到6位。
 console.log("a1234567890123456789的20位结果:"+/^[a-zA-Z]\w{5,19}$/.test("a1234567890123456789"));//20位
 console.log("a12345678901234567890的21位结果:"+/^[a-zA-Z]\w{5,19}$/.test("a12345678901234567890"));//21位,位数不符合
 console.log("1234a的以数字开头的结果:"+/^[a-zA-Z]\w{5,19}$/.test("1234a"));//以数字开头,不符合
 console.log("a123-4a的含短线的结果:"+/^[a-zA-Z]\w{5,19}$/.test("a123-4a"));//含短线特殊字符,不符合

 console.log("-----允许含有短线的另一个正则表达式----")
 console.log("a123-4的6带-结果:"+/^[a-zA-Z][\w-]{5,19}$/.test("a123-4"));//含有短线的,符合
 console.log("----用大小写字母和数字下划线替换\w----");
//用大小写字母和数字下划线替换\w
 console.log("a1234的5位结果:"+/^[a-zA-Z][a-zA-Z0-9_]{5,19}$/.test("a1234"));//5位,位数不符合
 console.log("a12345的6位结果:"+/^[a-zA-Z][a-zA-Z0-9_]{5,19}$/.test("a12345"));//6位
 console.log("a123-4a的含短线的结果:"+/^[a-zA-Z][a-zA-Z0-9_]{5,19}$/.test("a123-4a"));//含短线特殊字符,不符合
 console.log("a123-4a的含短线的结果:"+/^[a-zA-Z][a-zA-Z0-9_-]{5,19}$/.test("a123-4a"));//含短线特殊字符,不符合
  };
</script> 

图示:

posted @ 2019-11-15 11:29  花谢悦神  阅读(1385)  评论(0编辑  收藏  举报