JavaScript中常用的驗證reg
更新時間:2016年10月13日 10:37:53 作者:yangzailu
js驗證實用性非常高,用途非常廣泛,用于校驗ip地址的格式等操作,本文給大家介紹JavaScript中常用的驗證reg,非常不錯,具有參考借鑒價值,感興趣的朋友一起看看吧
不錯的JS驗證~~~~~~~~~~~~~~~~~~~~~~~~~
用途:校驗ip地址的格式
輸入:strIP:ip地址
返回:如果通過驗證返回true,否則返回false;
*/ function isIP(strIP) { if (isNull(strIP)) return false; var re=/^(\d+)\.(\d+)\.(\d+)\.(\d+)$/g //匹配IP地址的正則表達式 if(re.test(strIP)) { if( RegExp.$1 <256 && RegExp.$2<256 && RegExp.$3<256 && RegExp.$4<256) return true; } return false; } /* 用途:檢查輸入字符串是否為空或者全部都是空格 輸入:str 返回: 如果全是空返回true,否則返回false */ function isNull( str ){ if ( str == "" ) return true; var regu = "^[ ]+$"; var re = new RegExp(regu); return re.test(str); } /* 用途:檢查輸入對象的值是否符合整數(shù)格式 輸入:str 輸入的字符串 返回:如果通過驗證返回true,否則返回false */ function isInteger( str ){ var regu = /^[-]{0,1}[0-9]{1,}$/; return regu.test(str); } /* 用途:檢查輸入手機號碼是否正確 輸入: s:字符串 返回: 如果通過驗證返回true,否則返回false */ function checkMobile( s ){ var regu =/^[1][3][0-9]{9}$/; var re = new RegExp(regu); if (re.test(s)) { return true; }else{ return false; } } /* 用途:檢查輸入字符串是否符合正整數(shù)格式 輸入: s:字符串 返回: 如果通過驗證返回true,否則返回false */ function isNumber( s ){ var regu = "^[0-9]+$"; var re = new RegExp(regu); if (s.search(re) != -1) { return true; } else { return false; } } /* 用途:檢查輸入字符串是否是帶小數(shù)的數(shù)字格式,可以是負數(shù) 輸入: s:字符串 返回: 如果通過驗證返回true,否則返回false */ function isDecimal( str ){ if(isInteger(str)) return true; var re = /^[-]{0,1}(\d+)[\.]+(\d+)$/; if (re.test(str)) { if(RegExp.$1==0&&RegExp.$2==0) return false; return true; } else { return false; } } /* 用途:檢查輸入對象的值是否符合端口號格式 輸入:str 輸入的字符串 返回:如果通過驗證返回true,否則返回false */ function isPort( str ){ return (isNumber(str) && str<65536); } /* 用途:檢查輸入對象的值是否符合E-Mail格式 輸入:str 輸入的字符串 返回:如果通過驗證返回true,否則返回false */ function isEmail( str ){ var myReg = /^[-_A-Za-z0-9]+@([_A-Za-z0-9]+\.)+[A-Za-z0-9]{2,3}$/; if(myReg.test(str)) return true; return false; } /* 用途:檢查輸入字符串是否符合金額格式 格式定義為帶小數(shù)的正數(shù),小數(shù)點后最多三位 輸入: s:字符串 返回: 如果通過驗證返回true,否則返回false */ function isMoney( s ){ var regu = "^[0-9]+[\.][0-9]{0,3}$"; var re = new RegExp(regu); if (re.test(s)) { return true; } else { return false; } } /* 用途:檢查輸入字符串是否只由英文字母和數(shù)字和下劃線組成 輸入: s:字符串 返回: 如果通過驗證返回true,否則返回false */ function isNumberOr_Letter( s ){//判斷是否是數(shù)字或字母 var regu = "^[0-9a-zA-Z\_]+$"; var re = new RegExp(regu); if (re.test(s)) { return true; }else{ return false; } } /* 用途:檢查輸入字符串是否只由英文字母和數(shù)字組成 輸入: s:字符串 返回: 如果通過驗證返回true,否則返回false */ function isNumberOrLetter( s ){//判斷是否是數(shù)字或字母 var regu = "^[0-9a-zA-Z]+$"; var re = new RegExp(regu); if (re.test(s)) { return true; }else{ return false; } } /* 用途:檢查輸入字符串是否只由漢字、字母、數(shù)字組成 輸入: value:字符串 返回: 如果通過驗證返回true,否則返回false */ function isChinaOrNumbOrLett( s ){//判斷是否是漢字、字母、數(shù)字組成 var regu = "^[0-9a-zA-Z\u4e00-\u9fa5]+$"; var re = new RegExp(regu); if (re.test(s)) { return true; }else{ return false; } } /* 用途:判斷是否是日期 輸入:date:日期;fmt:日期格式 返回:如果通過驗證返回true,否則返回false */ function isDate( date, fmt ) { if (fmt==null) fmt="yyyyMMdd"; var yIndex = fmt.indexOf("yyyy"); if(yIndex==-1) return false; var year = date.substring(yIndex,yIndex+4); var mIndex = fmt.indexOf("MM"); if(mIndex==-1) return false; var month = date.substring(mIndex,mIndex+2); var dIndex = fmt.indexOf("dd"); if(dIndex==-1) return false; var day = date.substring(dIndex,dIndex+2); if(!isNumber(year)||year>"2100" || year< "1900") return false; if(!isNumber(month)||month>"12" || month< "01") return false; if(day>getMaxDay(year,month) || day< "01") return false; return true; } function getMaxDay(year,month) { if(month==4||month==6||month==9||month==11) return "30"; if(month==2) if(year%4==0&&year%100!=0 || year%400==0) return "29"; else return "28"; return "31"; } /* 用途:字符1是否以字符串2結束 輸入:str1:字符串;str2:被包含的字符串 返回:如果通過驗證返回true,否則返回false */ function isLastMatch(str1,str2) { var index = str1.lastIndexOf(str2); if(str1.length==index+str2.length) return true; return false; } /* 用途:字符1是否以字符串2開始 輸入:str1:字符串;str2:被包含的字符串 返回:如果通過驗證返回true,否則返回false */ function isFirstMatch(str1,str2) { var index = str1.indexOf(str2); if(index==0) return true; return false; } /* 用途:字符1是包含字符串2 輸入:str1:字符串;str2:被包含的字符串 返回:如果通過驗證返回true,否則返回false */ function isMatch(str1,str2) { var index = str1.indexOf(str2); if(index==-1) return false; return true; } /* 用途:檢查輸入的起止日期是否正確,規(guī)則為兩個日期的格式正確, 且結束如期>=起始日期 輸入: startDate:起始日期,字符串 endDate:結束如期,字符串 返回: 如果通過驗證返回true,否則返回false */ function checkTwoDate( startDate,endDate ) { if( !isDate(startDate) ) { alert("起始日期不正確!"); return false; } else if( !isDate(endDate) ) { alert("終止日期不正確!"); return false; } else if( startDate > endDate ) { alert("起始日期不能大于終止日期!"); return false; } return true; } /* 用途:檢查輸入的Email信箱格式是否正確 輸入: strEmail:字符串 返回: 如果通過驗證返回true,否則返回false */ function checkEmail(strEmail) { //var emailReg = /^[_a-z0-9]+@([_a-z0-9]+\.)+[a-z0-9]{2,3}$/; var emailReg = /^[\w-]+(\.[\w-]+)*@[\w-]+(\.[\w-]+)+$/; if( emailReg.test(strEmail) ){ return true; }else{ alert("您輸入的Email地址格式不正確!"); return false; } } /* 用途:檢查輸入的電話號碼格式是否正確 輸入: strPhone:字符串 返回: 如果通過驗證返回true,否則返回false */ function checkPhone( strPhone ) { var phoneRegWithArea = /^[0][1-9]{2,3}-[0-9]{5,10}$/; var phoneRegNoArea = /^[1-9]{1}[0-9]{5,8}$/; var prompt = "您輸入的電話號碼不正確!" if( strPhone.length > 9 ) { if( phoneRegWithArea.test(strPhone) ){ return true; }else{ alert( prompt ); return false; } }else{ if( phoneRegNoArea.test( strPhone ) ){ return true; }else{ alert( prompt ); return false; } } } /* 用途:檢查復選框被選中的數(shù)目 輸入: checkboxID:字符串 返回: 返回該復選框中被選中的數(shù)目 */ function checkSelect( checkboxID ) { var check = 0; var i=0; if( document.all(checkboxID).length > 0 ) { for( i=0; i<document.all(checkboxID).length; i++ ) { if( document.all(checkboxID).item( i ).checked ) { check += 1; } } }else{ if( document.all(checkboxID).checked ) check = 1; } return check; } function getTotalBytes(varField) { if(varField == null) return -1; var totalCount = 0; for (i = 0; i< varField.value.length; i++) { if (varField.value.charCodeAt(i) > 127) totalCount += 2; else totalCount++ ; } return totalCount; } function getFirstSelectedValue( checkboxID ){ var value = null; var i=0; if( document.all(checkboxID).length > 0 ){ for( i=0; i<document.all(checkboxID).length; i++ ){ if( document.all(checkboxID).item( i ).checked ){ value = document.all(checkboxID).item(i).value; break; } } } else { if( document.all(checkboxID).checked ) value = document.all(checkboxID).value; } return value; } function getFirstSelectedIndex( checkboxID ){ var value = -2; var i=0; if( document.all(checkboxID).length > 0 ){ for( i=0; i<document.all(checkboxID).length; i++ ) { if( document.all(checkboxID).item( i ).checked ) { value = i; break; } } } else { if( document.all(checkboxID).checked ) value = -1; } return value; } function selectAll( checkboxID,status ){ if( document.all(checkboxID) == null) return; if( document.all(checkboxID).length > 0 ){ for( i=0; i<document.all(checkboxID).length; i++ ){ document.all(checkboxID).item( i ).checked = status; } } else { document.all(checkboxID).checked = status; } } function selectInverse( checkboxID ) { if( document.all(checkboxID) == null) return; if( document.all(checkboxID).length > 0 ) { for( i=0; i<document.all(checkboxID).length; i++ ) { document.all(checkboxID).item( i ).checked = !document.all(checkboxID).item( i ).checked; } } else { document.all(checkboxID).checked = !document.all(checkboxID).checked; } } function checkDate( value ) { if(value=='') return true; if(value.length!=8 || !isNumber(value)) return false; var year = value.substring(0,4); if(year>"2100" || year< "1900") return false; var month = value.substring(4,6); if(month>"12" || month< "01") return false; var day = value.substring(6,8); if(day>getMaxDay(year,month) || day< "01") return false; return true; } /* 用途:檢查輸入的起止日期是否正確,規(guī)則為兩個日期的格式正確或都為空 且結束日期>=起始日期 輸入: startDate:起始日期,字符串 endDate: 結束日期,字符串 返回: 如果通過驗證返回true,否則返回false */ function checkPeriod( startDate,endDate ) { if( !checkDate(startDate) ) { alert("起始日期不正確!"); return false; } else if( !checkDate(endDate) ) { alert("終止日期不正確!"); return false; } else if( startDate > endDate ) { alert("起始日期不能大于終止日期!"); return false; } return true; } /* 用途:檢查證券代碼是否正確 輸入: secCode:證券代碼 返回: 如果通過驗證返回true,否則返回false */ function checkSecCode( secCode ) { if( secCode.length !=6 ){ alert("證券代碼長度應該為6位"); return false; } if(!isNumber( secCode ) ){ alert("證券代碼只能包含數(shù)字"); return false; } return true; } /**************************************************** function:cTrim(sInputString,iType) description:字符串去空格的函數(shù) parameters:iType:1=去掉字符串左邊的空格 2=去掉字符串左邊的空格 0=去掉字符串左邊和右邊的空格 return value:去掉空格的字符串 ****************************************************/ function cTrim(sInputString,iType) { var sTmpStr = ' '; var i = -1; if(iType == 0 || iType == 1) { while(sTmpStr == ' ') { ++i; sTmpStr = sInputString.substr(i,1); } sInputString = sInputString.substring(i); } if(iType == 0 || iType == 2) { sTmpStr = ' '; i = sInputString.length; while(sTmpStr == ' ') { --i; sTmpStr = sInputString.substr(i,1); } sInputString = sInputString.substring(0,i+1); } return sInputString; }
以上所述是小編給大家介紹的JavaScript中常用的驗證reg,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對腳本之家網站的支持!
相關文章
JavaScript數(shù)組實現(xiàn)扁平化四種方法詳解
扁平化,顧名思義就是減少復雜性裝飾,使其事物本身更簡潔、簡單,突出主題。數(shù)組扁平化,對著上面意思套也知道了,就是將一個復雜的嵌套多層的數(shù)組,一層一層的轉化為層級較少或者只有一層的數(shù)組2022-10-10JS中mouseover和mouseout多次觸發(fā)問題如何解決
這篇文章主要介紹了JS中mouseover和mouseout多次觸發(fā)問題如何解決的相關資料,非常不錯具有參考借鑒價值,需要的朋友可以參考下2016-06-06JavaScript中異步與回調的基本概念及回調地獄現(xiàn)象
這篇文章主要介紹了JavaScript中異步與回調的基本概念,以及回調地獄現(xiàn)象,本文主要介紹了異步和回調的基本概念,二者是JavaScript的核心內容,需要所有熱愛JS的小伙伴深入了解,需要的朋友可以參考下2022-07-07