javascript實現(xiàn)檢驗的各種規(guī)則
更新時間:2015年07月31日 12:30:17 作者:伯融
這篇文章主要介紹了javascript實現(xiàn)檢驗的各種規(guī)則,涉及javascript針對手機號、郵箱、網(wǎng)址、漢字及圖片等相關(guān)檢測技巧,具有一定參考借鑒價值,需要的朋友可以參考下
本文實例講述了javascript實現(xiàn)檢驗的各種規(guī)則。分享給大家供大家參考。具體如下:
/**
* 檢驗各種規(guī)則
* @param str 檢驗的內(nèi)容
* @param cType 預(yù)設(shè)的檢驗規(guī)則 字符串[
* empty, 檢驗是否為空
* telphone, 座機手機號碼
* allphone, 所有手機號碼
* ydphone, 移動手機號碼
* ltphone, 聯(lián)通手機號碼
* dxphone, 電信手機號碼
* email, 郵箱
* url, 網(wǎng)址
* cn, 漢字
* image, 圖片格式
* emscode, 郵政編碼
* isEmpty, 檢查是否為空
* isint, 整數(shù)
* isfloat, 判斷是否為正小數(shù)
* isnumber, 判斷為實數(shù)
* words, 判斷是否為英文字母
* wordsAndNum, 判斷是否為字母+數(shù)字
* wordsAndNumAndDownline, 判斷是否由數(shù)字、26個英文字母或者下劃線組成的字符串
* qq, QQ檢驗
* personCard18, 身份證18位
* personCard15, 身份證15位
* ]
* @param regex 自定義表達(dá)式 傳入格式例如:"^\-?[1-9]+\d*$"
*
* @description cType 與 regex 只能有一個為空
* 如 checkObjectByRegex("測試中文", "cn"); // 判斷中文
* 如 checkObjectByRegex("測試中文", null, "^[\u4e00-\u9fa5]+$"); // 自定義表達(dá)式正則
* @return {boolean}
*/
function checkObjectByRegex(str, cType, regex) {
/**
* 定義驗證各種格式類型的正則表達(dá)式對象
*/
var Regexs = {
telphone: (/^((\(\d{3}\))|(\d{3}\-))?(\(0\d{2,3}\)|0\d{2,3}-)?[1-9]\d{6,7}$/), //座機手機號碼
allphone: (/^((13[0-9])|(14[57])|(15[0-9])|(17[678])|(18[0-9]))[0-9]{8}$/), //所有手機號碼
ydphone: (/^((13[4-9])|(15[012789])|147|178|(18[23478]))[0-9]{8}$/), //移動手機號碼
ltphone: (/^((13[0-2])|(145)|(15[56])|(176)|(18[56]))[0-9]{8}$/), //聯(lián)通手機號碼
dxphone: (/^((133)|(153)|(177)|(180)|(181)|(189))[0-9]{8}$/), //電信手機號碼
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ù)
words: (/^[A-Za-z]+$/), //判斷是否為英文字母
wordsAndNum: (/^[A-Za-z0-9]+$/), //判斷是否為字母+數(shù)字
wordsAndNumAndDownline: (/^\w+$/), //判斷是否由數(shù)字、26個英文字母或者下劃線組成的字符串
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)為是驗證通過
// 針對 18位身份證單獨處理
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位身份證單獨處理
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è)計有所幫助。
相關(guān)文章
利用JavaScript實現(xiàn)3D可旋轉(zhuǎn)粒子矩陣效果
dat.gui.js是一個一個輕量級的圖形用戶界面庫,或者說GUI組件,只有幾十KB,可以用于創(chuàng)建操作控制三維場景的菜單欄等。本文將利用dat.gui.min.js實現(xiàn)3D可旋轉(zhuǎn)粒子矩陣效果,感興趣的可以了解一下2022-06-06
最簡單純JavaScript實現(xiàn)Tab標(biāo)簽頁切換的方式(推薦)
這篇文章主要介紹了最簡單純JavaScript實現(xiàn)Tab標(biāo)簽頁切換的方式(推薦)的相關(guān)資料,非常不錯,具有參考借鑒價值,需要的朋友可以參考下2016-07-07
JavaScript中遞歸實現(xiàn)的方法及其區(qū)別
遞歸函數(shù)是在通過名字調(diào)用自身的情況下構(gòu)成的。下面通過本文給大家分享JavaScript中遞歸實現(xiàn)的方法及其區(qū)別,感興趣的朋友一起看看吧2017-09-09
ES6 新增的創(chuàng)建數(shù)組的方法(小結(jié))
這篇文章主要介紹了ES6 新增的創(chuàng)建數(shù)組的方法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-08-08

