悲伤的小丑 發表於 2022-3-14 11:22:05

在nest.js中通过正则表达式正确设置验证的方法

<p>下面看下nest.js正则表达式设置验证的方法,代码如下所示:</p>
<div class="jb51code"><pre class="brush:plain;">import
{
IsNotEmpty, Length, Matches, Max, Min } from "class-validator";
const phoneReg = /^1(3\d|4|5|6|7|8\d|9)\d{8}$/</pre></div>
<p style="text-align:center"><img alt="" src="https://img.jbzj.com/file_images/article/202203/2022314110123676.png?202221411149" /></p>
<p><span style="color:#e74c3c">补充:下面看下js正则表达式验证大全</span></p>
<div class="jb51code"><pre class="brush:js;">/判断输入内容是否为空    
function IsNull(){    
    var str = document.getElementById('str').value.trim();    
    if(str.length==0){    
        alert('对不起,文本框不能为空或者为空格!');//请将“文本框”改成你需要验证的属性名称!    
    }    
}    
   
//判断日期类型是否为YYYY-MM-DD格式的类型    
function IsDate(){     
    if(str.length!=0){    
        var reg = /^(\d{1,4})(-|\/)(\d{1,2})\2(\d{1,2})$/;     
        var r = str.match(reg);     
        if(r==null)    
            alert('对不起,您输入的日期格式不正确!'); //请将“日期”改成你需要验证的属性名称!    
        }    
}     
//判断日期类型是否为YYYY-MM-DD hh:mm:ss格式的类型    
function IsDateTime(){     
        var reg = /^(\d{1,4})(-|\/)(\d{1,2})\2(\d{1,2}) (\d{1,2}):(\d{1,2}):(\d{1,2})$/;     
        alert('对不起,您输入的日期格式不正确!'); //请将“日期”改成你需要验证的属性名称!    
//判断日期类型是否为hh:mm:ss格式的类型    
function IsTime()     
{     
    reg=/^((20|21|22|23|\d)\:)(\:)?$/     
        if(!reg.test(str)){    
            alert("对不起,您输入的日期格式不正确!");//请将“日期”改成你需要验证的属性名称!    
//判断输入的字符是否为英文字母    
function IsLetter()     
        var str = document.getElementById('str').value.trim();    
        if(str.length!=0){    
        reg=/^+$/;     
            alert("对不起,您输入的英文字母类型格式不正确!");//请将“英文字母类型”改成你需要验证的属性名称!    
//判断输入的字符是否为整数    
function IsInteger()     
{       
        reg=/^[-+]?\d*$/;     
            alert("对不起,您输入的整数类型格式不正确!");//请将“整数类型”要换成你要验证的那个属性名称!    
//判断输入的字符是否为双精度    
function IsDouble(val)     
        reg=/^[-\+]?\d+(\.\d+)?$/;    
            alert("对不起,您输入的双精度类型格式不正确!");//请将“双精度类型”要换成你要验证的那个属性名称!    
//判断输入的字符是否为:a-z,A-Z,0-9    
function IsString()     
        reg=/^+$/;     
            alert("对不起,您输入的字符串类型格式不正确!");//请将“字符串类型”要换成你要验证的那个属性名称!    
//判断输入的字符是否为中文    
function IsChinese()     
        reg=/^[\u0391-\uFFE5]+$/;    
//判断输入的EMAIL格式是否正确    
function IsEmail()     
        reg=/^\w+([-+.]\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)*$/;    
//判断输入的邮编(只能为六位)是否正确    
function IsZIP()     
        reg=/^\d{6}$/;    
//判断输入的数字不大于某个特定的数字    
function MaxValue()     
    var val = document.getElementById('str').value.trim();    
        if(!reg.test(str)){//判断是否为数字类型    
            if(val&gt;parseInt('123')) //“123”为自己设定的最大值    
            {     
                alert('对不起,您输入的数字超出范围');//请将“数字”改成你要验证的那个属性名称!    
            }     
 Phone : /^((\(\d{2,3}\))|(\d{3}\-))?(\(0\d{2,3}\)|0\d{2,3}-)?\d{6,7}(\-\d{1,4})?$/    
 Mobile : /^((\(\d{2,3}\))|(\d{3}\-))?13\d{9}$/    
 Url : /^http:\/\/+\.+[\/=\?%\-&amp;_~`@[\]\':+!]*([^&lt;&gt;\"\"])*$/   
 IdCard : /^\d{15}(\d{2})?$/   
 QQ : /^\d{4,8}$/   
 某种特殊金额:/^((\d{1,3}(,\d{3})*)|(\d+))(\.\d{2})?$/               //说明:除“XXX    XX,XXX    XX,XXX.00”格式外

//为上面提供各个JS验证方法提供.trim()属性   
String.prototype.trim=function(){   
        return this.replace(/(^\s*)|(\s*$)/g, "");    
    }
调用:
&lt;input type="text" name="str" &gt;
&lt;input type="button" value=" 确定 " onClick=""&gt;    //onClick中写自己要调用的JS验证函数
&lt;script language="javascript" type="text/javascript"&gt;
var patterms = new Object();
//验证IP
patterms.ip = /^(\d{1,2}|1\d\d|2\d|25)(\.(\d{1,2}|1\d\d|2\d|25)){3}$/;
//验证EMAIL
patterms.email = /^+@+(\.+)+$/;
//验证日期格式2009-07-13
patterms.date = /^\d{4}-(0?|1)-(0?|\d|3)$/;
//验证时间格式16:55:39
patterms.time = new RegExp("^(\\d|2):\\d:\\d$");
//验证函数
function verify(str,pat)
{
    var thePat;
    thePat = patterms;
    if(thePat.test(str))
    {
        return true;
    }
    else
        return false;
}
//测试
alert(verify("asidycom@163.com","email")+","+verify("192.168.1.1","ip")+
    ","+verify("16:55:39","time")+","+verify("2009-07-13","date")+","+verify("192.168","ip"));</pre></div>
<p>验证数字:^*$&nbsp;</p>
<p>验证n位的数字:^\d{n}$&nbsp;&nbsp;</p>
<p>验证至少n位数字:^\d{n,}$&nbsp;</p>
<p>验证m-n位的数字:^\d{m,n}$&nbsp;</p>
<p>验证零和非零开头的数字:^(0|*)$&nbsp;</p>
<p>验证有两位小数的正实数:^+(.{2})?$&nbsp;</p>
<p>验证有1-3位小数的正实数:^+(.{1,3})?$&nbsp;</p>
<p>验证非零的正整数:^\+?*$&nbsp;</p>
<p>验证非零的负整数:^\-*$&nbsp;</p>
<p>验证非负整数(正整数 + 0) ^\d+$&nbsp;</p>
<p>验证非正整数(负整数 + 0) ^((-\d+)|(0+))$&nbsp;</p>
<p>验证长度为3的字符:^.{3}$&nbsp;</p>
<p>验证由26个英文字母组成的字符串:^+$&nbsp;</p>
<p>验证由26个大写英文字母组成的字符串:^+$&nbsp;</p>
<p>验证由26个小写英文字母组成的字符串:^+$&nbsp;</p>
<p>验证由数字和26个英文字母组成的字符串:^+$&nbsp;</p>
<p>验证由数字、26个英文字母或者下划线组成的字符串:^\w+$&nbsp;</p>
<p>验证用户名或昵称经常用到:&nbsp;^[\u4e00-\u9fa5A-Za-z0-9-_]*$ &nbsp;只能中英文,数字,下划线,减号</p>
<p>验证用户密码:^\w{5,17}$ 正确格式为:以字母开头,长度在6-18之间,只能包含字符、数字和下划线。&nbsp;</p>
<p>验证是否含有 ^%&amp;&#39;,;=?$\&quot; 等字符:[^%&amp;&#39;,;=?$\x22]+&nbsp;</p>
<p>验证汉字:^[\u4e00-\u9fa5],{0,}$&nbsp;</p>
<p>验证Email地址:^\w+[-+.]\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)*$&nbsp;</p>
<p>验证InternetURL:^http://([\w-]+\.)+[\w-]+(/[\w-./?%&amp;=]*)?$ ;^+://(w+(-w+)*)(.(w+(-w+)*))*(?S*)?$&nbsp;</p>
<p>验证电话号码:^(\(\d{3,4}\)|\d{3,4}-)?\d{7,8}$:--正确格式为:XXXX-XXXXXXX,XXXX-XXXXXXXX,XXX-XXXXXXX,XXX-XXXXXXXX,XXXXXXX,XXXXXXXX。&nbsp;</p>
<p>验证身份证号(15位或18位数字):^\d{15}|\d{}18$&nbsp;</p>
<p>验证一年的12个月:^(0?|1)$ 正确格式为:&ldquo;01&rdquo;-&ldquo;09&rdquo;和&ldquo;1&rdquo;&ldquo;12&rdquo;&nbsp;</p>
<p>验证一个月的31天:^((0?)|((1|2))|30|31)$ 正确格式为:01、09和1、31。&nbsp;</p>
<p>整数:^-?\d+$&nbsp;</p>
<p>非负浮点数(正浮点数 + 0):^\d+(\.\d+)?$&nbsp;</p>
<p>正浮点数 ^((+\.**)|(**\.+)|(**))$&nbsp;</p>
<p>非正浮点数(负浮点数 + 0) ^((-\d+(\.\d+)?)|(0+(\.0+)?))$&nbsp;</p>
<p>负浮点数 ^(-((+\.**)|(**\.+)|(**)))$&nbsp;</p>
<p>浮点数 ^(-?\d+)(\.\d+)?$</p>
<p>由于手机号段的不断更新,以前的正则表达式已经无法满足需求。</p>
<div class="jb51code"><pre class="brush:js;">var regex = {
    mobile: /^0?(13|15|18|14){8}$/
}</pre></div>
<p><strong>表达式分析:</strong></p>
<p>&ldquo;/&rdquo;代表一个正则表达式。</p>
<p>&ldquo;^&rdquo;代表字符串的开始位置,&ldquo;$&rdquo;代表字符串的结束位置。</p>
<p>&ldquo;?&rdquo;代表匹配前面的字符一个或零个,所以这里0?的意思是手机号码可以以0开头或不以0开头。</p>
<p>接下的部分验证11位的手机号码,先从13开始,因为从130-139都有所以可选区间是,15开头的号码没有154所以[]里面没有4这个数字,当然也可以写成,下面18和14开的号码同上。</p>
<p>小括号括起来的代表一个子表达式,里面是4个可选分支分别用&ldquo;|&rdquo;来区分开来,在正则中&ldquo;|&rdquo;的优先级是最低的,这里每个分支匹配的都是3个字符(一个[]只能匹配一个字符,里面是可选的意思),也就是</p>
<p>手机号码的前3位数字,那么后面还有8位数字需要匹配,可以是0-9的任意字符,所以是&ldquo;{8}&rdquo;,{}中的数字代表匹配前面字符的个数。分析完毕。</p>
頁: [1]
查看完整版本: 在nest.js中通过正则表达式正确设置验证的方法