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 預設的檢驗規(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 自定義表達式 傳入格式例如:"^\-?[1-9]+\d*$" * * @description cType 與 regex 只能有一個為空 * 如 checkObjectByRegex("測試中文", "cn"); // 判斷中文 * 如 checkObjectByRegex("測試中文", null, "^[\u4e00-\u9fa5]+$"); // 自定義表達式正則 * @return {boolean} */ function checkObjectByRegex(str, cType, regex) { /** * 定義驗證各種格式類型的正則表達式對象 */ 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; //輸入為空,認為是驗證通過 // 針對 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 { // 自定義正則表達式處理 if (regex != null && typeof(regex) != "undefined") { nReg = new RegExp(regex); } else { return false; } } return nReg.test(str); }
希望本文所述對大家的javascript程序設計有所幫助。
相關(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標簽頁切換的方式(推薦)
這篇文章主要介紹了最簡單純JavaScript實現(xiàn)Tab標簽頁切換的方式(推薦)的相關(guān)資料,非常不錯,具有參考借鑒價值,需要的朋友可以參考下2016-07-07JavaScript中遞歸實現(xiàn)的方法及其區(qū)別
遞歸函數(shù)是在通過名字調(diào)用自身的情況下構(gòu)成的。下面通過本文給大家分享JavaScript中遞歸實現(xiàn)的方法及其區(qū)別,感興趣的朋友一起看看吧2017-09-09ES6 新增的創(chuàng)建數(shù)組的方法(小結(jié))
這篇文章主要介紹了ES6 新增的創(chuàng)建數(shù)組的方法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2019-08-08