javascript實(shí)現(xiàn)檢驗(yàn)的各種規(guī)則
本文實(shí)例講述了javascript實(shí)現(xiàn)檢驗(yàn)的各種規(guī)則。分享給大家供大家參考。具體如下:
/**
* 檢驗(yàn)各種規(guī)則
* @param str 檢驗(yàn)的內(nèi)容
* @param cType 預(yù)設(shè)的檢驗(yàn)規(guī)則 字符串[
* empty, 檢驗(yàn)是否為空
* telphone, 座機(jī)手機(jī)號碼
* allphone, 所有手機(jī)號碼
* ydphone, 移動(dòng)手機(jī)號碼
* ltphone, 聯(lián)通手機(jī)號碼
* dxphone, 電信手機(jī)號碼
* email, 郵箱
* url, 網(wǎng)址
* cn, 漢字
* image, 圖片格式
* emscode, 郵政編碼
* isEmpty, 檢查是否為空
* isint, 整數(shù)
* isfloat, 判斷是否為正小數(shù)
* isnumber, 判斷為實(shí)數(shù)
* words, 判斷是否為英文字母
* wordsAndNum, 判斷是否為字母+數(shù)字
* wordsAndNumAndDownline, 判斷是否由數(shù)字、26個(gè)英文字母或者下劃線組成的字符串
* qq, QQ檢驗(yàn)
* personCard18, 身份證18位
* personCard15, 身份證15位
* ]
* @param regex 自定義表達(dá)式 傳入格式例如:"^\-?[1-9]+\d*$"
*
* @description cType 與 regex 只能有一個(gè)為空
* 如 checkObjectByRegex("測試中文", "cn"); // 判斷中文
* 如 checkObjectByRegex("測試中文", null, "^[\u4e00-\u9fa5]+$"); // 自定義表達(dá)式正則
* @return {boolean}
*/
function checkObjectByRegex(str, cType, regex) {
/**
* 定義驗(yàn)證各種格式類型的正則表達(dá)式對象
*/
var Regexs = {
telphone: (/^((\(\d{3}\))|(\d{3}\-))?(\(0\d{2,3}\)|0\d{2,3}-)?[1-9]\d{6,7}$/), //座機(jī)手機(jī)號碼
allphone: (/^((13[0-9])|(14[57])|(15[0-9])|(17[678])|(18[0-9]))[0-9]{8}$/), //所有手機(jī)號碼
ydphone: (/^((13[4-9])|(15[012789])|147|178|(18[23478]))[0-9]{8}$/), //移動(dòng)手機(jī)號碼
ltphone: (/^((13[0-2])|(145)|(15[56])|(176)|(18[56]))[0-9]{8}$/), //聯(lián)通手機(jī)號碼
dxphone: (/^((133)|(153)|(177)|(180)|(181)|(189))[0-9]{8}$/), //電信手機(jī)號碼
email: (/^([a-zA-Z0-9_-])+@([a-zA-Z0-9_-])+((\.[a-zA-Z0-9_-]{2,3}){1,2})$/),//郵箱
url: (/(?:https|http|ftp|rtsp|mms):\/\/.+\/[\w]+\.[\w]+/), //網(wǎng)址
cn: (/^[\u4e00-\u9fa5]+$/i), //漢字
image: (/\.jpg$|\.jpeg$|\.png$/i), //圖片格式
emscode: (/^[1-9]\d{5}$/), //郵政編碼
isint: (/^(\-)?[1-9]+\d*$/), //整數(shù)
isfloat: (/^[0-9]+\.?[0-9]*$/), //判斷是否為正小數(shù)
isnumber: (/^[-\+]?\d+(\.\d+)?$/), //判斷為實(shí)數(shù)
words: (/^[A-Za-z]+$/), //判斷是否為英文字母
wordsAndNum: (/^[A-Za-z0-9]+$/), //判斷是否為字母+數(shù)字
wordsAndNumAndDownline: (/^\w+$/), //判斷是否由數(shù)字、26個(gè)英文字母或者下劃線組成的字符串
qq: (/^[1-9]\d{4,11}$/), //QQ
personCard18: (/^(\d{6})()?(\d{4})(\d{2})(\d{2})(\d{3})(\d|X)$/), //身份證18位
personCard15: (/^(\d{6})()?(\d{2})(\d{2})(\d{2})(\d{3})$/) //身份證15位
};
var nReg;
if (str == null || typeof(str) == "undefined") {
str = "";
}
if (cType != null && typeof(cType) != "undefined") {
if (cType == "isEmpty") {
str = $.trim(str);
if (str != null && typeof(str) != "undefined" && str != "") {
return false;
} else return true;
}
nReg = Regexs[cType];
if (str == null || str == "") return false; //輸入為空,認(rèn)為是驗(yàn)證通過
// 針對 18位身份證單獨(dú)處理
if (cType == 'personCard18') {
var ary = str.match(Regexs[cType]);
if (!(parseInt(ary[3]) >= 1900)) return false;
var D = new Date(ary[3] + "/" + ary[4] + "/" + ary[5]);
var isTrue = D.getFullYear() == ary[3] && (D.getMonth() + 1) == ary[4] && D.getDate() == ary[5];
return isTrue;
}
// 針對 15位身份證單獨(dú)處理
if (cType == 'personCard15') {
var ary = str.match(Regexs[cType]);
var D = new Date("19" + ary[3] + "/" + ary[4] + "/" + ary[5]);
var isTrue = D.getYear() == ary[3] && (D.getMonth() + 1) == ary[4] && D.getDate() == ary[5];
return isTrue;
}
} else {
// 自定義正則表達(dá)式處理
if (regex != null && typeof(regex) != "undefined") {
nReg = new RegExp(regex);
} else {
return false;
}
}
return nReg.test(str);
}
希望本文所述對大家的javascript程序設(shè)計(jì)有所幫助。
- js檢驗(yàn)密碼強(qiáng)度(低中高)附圖
- 中文用戶名的js檢驗(yàn)正則
- 編寫Js代碼要注意的幾條規(guī)則
- javascript實(shí)現(xiàn)的簡單的表單驗(yàn)證
- 詳解JavaScript中的表單驗(yàn)證
- javascript驗(yàn)證郵件地址和MX記錄的方法
- JavaScript實(shí)現(xiàn)仿網(wǎng)易通行證表單驗(yàn)證
- javascript實(shí)現(xiàn)驗(yàn)證IP地址等相關(guān)信息代碼
- javascript實(shí)現(xiàn)驗(yàn)證身份證號的有效性并提示
- JavaScript常用驗(yàn)證函數(shù)實(shí)例匯總
- JavaScript驗(yàn)證電子郵箱的函數(shù)
相關(guān)文章
Echarts.js實(shí)現(xiàn)水滴球和海洋效果
這篇文章介紹了Echarts.js實(shí)現(xiàn)水滴球和海洋效果的方法,文中通過示例代碼介紹的非常詳細(xì)。對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-04-04
查找頁面中所有類為test的結(jié)點(diǎn)的方法
這篇文章主要介紹了查找頁面中所有類為test結(jié)點(diǎn)的方法,需要的朋友可以參考下2014-03-03
javascript 實(shí)現(xiàn)自由落體的方塊效果
這其實(shí)是一個(gè)很簡單的實(shí)現(xiàn),create一個(gè)新的div元素,然后append到文檔的body上,經(jīng)過一定時(shí)間的延遲,做自由落體運(yùn)動(dòng),著地后fade消失。 不多說,直接上代碼。2010-01-01
利用JavaScript實(shí)現(xiàn)3D可旋轉(zhuǎn)粒子矩陣效果
dat.gui.js是一個(gè)一個(gè)輕量級的圖形用戶界面庫,或者說GUI組件,只有幾十KB,可以用于創(chuàng)建操作控制三維場景的菜單欄等。本文將利用dat.gui.min.js實(shí)現(xiàn)3D可旋轉(zhuǎn)粒子矩陣效果,感興趣的可以了解一下2022-06-06
最簡單純JavaScript實(shí)現(xiàn)Tab標(biāo)簽頁切換的方式(推薦)
這篇文章主要介紹了最簡單純JavaScript實(shí)現(xiàn)Tab標(biāo)簽頁切換的方式(推薦)的相關(guān)資料,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下2016-07-07
JavaScript中遞歸實(shí)現(xiàn)的方法及其區(qū)別
遞歸函數(shù)是在通過名字調(diào)用自身的情況下構(gòu)成的。下面通過本文給大家分享JavaScript中遞歸實(shí)現(xiàn)的方法及其區(qū)別,感興趣的朋友一起看看吧2017-09-09
ES6 新增的創(chuàng)建數(shù)組的方法(小結(jié))
這篇文章主要介紹了ES6 新增的創(chuàng)建數(shù)組的方法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-08-08

