在nest.js中通過正則表達式正確設置驗證的方法
下面看下nest.js正則表達式設置驗證的方法,代碼如下所示:
import
{
IsNotEmpty, Length, Matches, Max, Min } from "class-validator";
const phoneReg = /^1(3\d|4[5-9]|5[0-35-9]|6[567]|7[0-8]|8\d|9[0-35-9])\d{8}$/
補充:下面看下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|[0-1]\d)\:[0-5][0-9])(\:[0-5][0-9])?$/?????
??????? if(!reg.test(str)){????
??????????? alert("對不起,您輸入的日期格式不正確!");//請將“日期”改成你需要驗證的屬性名稱!????
//判斷輸入的字符是否為英文字母????
function IsLetter()?????
??????? var str = document.getElementById('str').value.trim();????
??????? if(str.length!=0){????
??????? reg=/^[a-zA-Z]+$/;?????
??????????? alert("對不起,您輸入的英文字母類型格式不正確!");//請將“英文字母類型”改成你需要驗證的屬性名稱!????
//判斷輸入的字符是否為整數(shù)????
function IsInteger()?????
{???????
??????? reg=/^[-+]?\d*$/;?????
??????????? alert("對不起,您輸入的整數(shù)類型格式不正確!");//請將“整數(shù)類型”要換成你要驗證的那個屬性名稱!????
//判斷輸入的字符是否為雙精度????
function IsDouble(val)?????
??????? reg=/^[-\+]?\d+(\.\d+)?$/;????
??????????? alert("對不起,您輸入的雙精度類型格式不正確!");//請將“雙精度類型”要換成你要驗證的那個屬性名稱!????
//判斷輸入的字符是否為:a-z,A-Z,0-9????
function IsString()?????
??????? reg=/^[a-zA-Z0-9_]+$/;?????
??????????? alert("對不起,您輸入的字符串類型格式不正確!");//請將“字符串類型”要換成你要驗證的那個屬性名稱!????
//判斷輸入的字符是否為中文????
function IsChinese()?????
??????? reg=/^[\u0391-\uFFE5]+$/;????
//判斷輸入的EMAIL格式是否正確????
function IsEmail()?????
??????? reg=/^\w+([-+.]\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)*$/;????
//判斷輸入的郵編(只能為六位)是否正確????
function IsZIP()?????
??????? reg=/^\d{6}$/;????
//判斷輸入的數(shù)字不大于某個特定的數(shù)字????
function MaxValue()?????
??? var val = document.getElementById('str').value.trim();????
??????? if(!reg.test(str)){//判斷是否為數(shù)字類型????
??????????? if(val>parseInt('123')) //“123”為自己設定的最大值????
??????????? {?????
??????????????? alert('對不起,您輸入的數(shù)字超出范圍');//請將“數(shù)字”改成你要驗證的那個屬性名稱!????
??????????? }?????
?Phone : /^((\(\d{2,3}\))|(\d{3}\-))?(\(0\d{2,3}\)|0\d{2,3}-)?[1-9]\d{6,7}(\-\d{1,4})?$/????
?Mobile : /^((\(\d{2,3}\))|(\d{3}\-))?13\d{9}$/????
?Url : /^http:\/\/[A-Za-z0-9]+\.[A-Za-z0-9]+[\/=\?%\-&_~`@[\]\':+!]*([^<>\"\"])*$/???
?IdCard : /^\d{15}(\d{2}[A-Za-z0-9])?$/???
?QQ : /^[1-9]\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, "");????
??? }
調用:
<input type="text" name="str" >
<input type="button" value=" 確定 " onClick="">??? //onClick中寫自己要調用的JS驗證函數(shù)
<script?language="javascript"?type="text/javascript">
var?patterms?=?new?Object();
//驗證IP
patterms.ip?=?/^(\d{1,2}|1\d\d|2[0-4]\d|25[0-5])(\.(\d{1,2}|1\d\d|2[0-4]\d|25[0-5])){3}$/;
//驗證EMAIL
patterms.email?=?/^[a-zA-Z0-9_-]+@[a-zA-Z0-9_-]+(\.[a-zA-Z0-9_-]+)+$/;
//驗證日期格式2009-07-13
patterms.date?=?/^\d{4}-(0?[1-9]|1[0-2])-(0?[1-9]|[1-2]\d|3[0-1])$/;
//驗證時間格式16:55:39
patterms.time?=?new?RegExp("^([0-1]\\d|2[0-3]):[0-5]\\d:[0-5]\\d$");
//驗證函數(shù)
function?verify(str,pat)
{
????var?thePat;
????thePat?=?patterms[pat];
????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"));驗證數(shù)字:^[0-9]*$
驗證n位的數(shù)字:^\d{n}$
驗證至少n位數(shù)字:^\d{n,}$
驗證m-n位的數(shù)字:^\d{m,n}$
驗證零和非零開頭的數(shù)字:^(0|[1-9][0-9]*)$
驗證有兩位小數(shù)的正實數(shù):^[0-9]+(.[0-9]{2})?$
驗證有1-3位小數(shù)的正實數(shù):^[0-9]+(.[0-9]{1,3})?$
驗證非零的正整數(shù):^\+?[1-9][0-9]*$
驗證非零的負整數(shù):^\-[1-9][0-9]*$
驗證非負整數(shù)(正整數(shù) + 0) ^\d+$
驗證非正整數(shù)(負整數(shù) + 0) ^((-\d+)|(0+))$
驗證長度為3的字符:^.{3}$
驗證由26個英文字母組成的字符串:^[A-Za-z]+$
驗證由26個大寫英文字母組成的字符串:^[A-Z]+$
驗證由26個小寫英文字母組成的字符串:^[a-z]+$
驗證由數(shù)字和26個英文字母組成的字符串:^[A-Za-z0-9]+$
驗證由數(shù)字、26個英文字母或者下劃線組成的字符串:^\w+$
驗證用戶名或昵稱經(jīng)常用到: ^[\u4e00-\u9fa5A-Za-z0-9-_]*$ 只能中英文,數(shù)字,下劃線,減號
驗證用戶密碼:^[a-zA-Z]\w{5,17}$ 正確格式為:以字母開頭,長度在6-18之間,只能包含字符、數(shù)字和下劃線。
驗證是否含有 ^%&',;=?$\" 等字符:[^%&',;=?$\x22]+
驗證漢字:^[\u4e00-\u9fa5],{0,}$
驗證Email地址:^\w+[-+.]\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)*$
驗證InternetURL:^http://([\w-]+\.)+[\w-]+(/[\w-./?%&=]*)?$ ;^[a-zA-z]+://(w+(-w+)*)(.(w+(-w+)*))*(?S*)?$
驗證電話號碼:^(\(\d{3,4}\)|\d{3,4}-)?\d{7,8}$:--正確格式為:XXXX-XXXXXXX,XXXX-XXXXXXXX,XXX-XXXXXXX,XXX-XXXXXXXX,XXXXXXX,XXXXXXXX。
驗證身份證號(15位或18位數(shù)字):^\d{15}|\d{}18$
驗證一年的12個月:^(0?[1-9]|1[0-2])$ 正確格式為:“01”-“09”和“1”“12”
驗證一個月的31天:^((0?[1-9])|((1|2)[0-9])|30|31)$ 正確格式為:01、09和1、31。
整數(shù):^-?\d+$
非負浮點數(shù)(正浮點數(shù) + 0):^\d+(\.\d+)?$
正浮點數(shù) ^(([0-9]+\.[0-9]*[1-9][0-9]*)|([0-9]*[1-9][0-9]*\.[0-9]+)|([0-9]*[1-9][0-9]*))$
非正浮點數(shù)(負浮點數(shù) + 0) ^((-\d+(\.\d+)?)|(0+(\.0+)?))$
負浮點數(shù) ^(-(([0-9]+\.[0-9]*[1-9][0-9]*)|([0-9]*[1-9][0-9]*\.[0-9]+)|([0-9]*[1-9][0-9]*)))$
浮點數(shù) ^(-?\d+)(\.\d+)?$
由于手機號段的不斷更新,以前的正則表達式已經(jīng)無法滿足需求。
var regex = {
mobile: /^0?(13[0-9]|15[012356789]|18[0236789]|14[57])[0-9]{8}$/
}表達式分析:
“/”代表一個正則表達式。
“^”代表字符串的開始位置,“$”代表字符串的結束位置。
“?”代表匹配前面的字符一個或零個,所以這里0?的意思是手機號碼可以以0開頭或不以0開頭。
接下的部分驗證11位的手機號碼,先從13開始,因為從130-139都有所以可選區(qū)間是[0-9],15開頭的號碼沒有154所以[]里面沒有4這個數(shù)字,當然也可以寫成[0-35-9],下面18和14開的號碼同上。
小括號括起來的代表一個子表達式,里面是4個可選分支分別用“|”來區(qū)分開來,在正則中“|”的優(yōu)先級是最低的,這里每個分支匹配的都是3個字符(一個[]只能匹配一個字符,里面是可選的意思),也就是
手機號碼的前3位數(shù)字,那么后面還有8位數(shù)字需要匹配,可以是0-9的任意字符,所以是“[0-9]{8}”,{}中的數(shù)字代表匹配前面字符的個數(shù)。分析完畢。
到此這篇關于在nest.js中通過正則表達式正確設置驗證的方法的文章就介紹到這了,更多相關nest.js正則表達式設置驗證內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
editplus EmEditor和searchandreplace正則表達式
掌握下面的正則方便我們快速的批量處理文本替換。2009-07-07
[js]用JAVASCRIPT正則表達式限制文本字節(jié)數(shù)的代碼
[js]用JAVASCRIPT正則表達式限制文本字節(jié)數(shù)的代碼...2007-11-11
javascript中基于replace函數(shù)的正則表達式語法
replace()最js中比較簡單的字符替換函數(shù),但是它也是可以跟正則結合實現(xiàn)強大的字符替換效果。2011-02-02

