欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

javascript實(shí)現(xiàn)檢驗(yàn)的各種規(guī)則

 更新時(shí)間:2015年07月31日 12:30:17   作者:伯融  
這篇文章主要介紹了javascript實(shí)現(xiàn)檢驗(yàn)的各種規(guī)則,涉及javascript針對(duì)手機(jī)號(hào)、郵箱、網(wǎng)址、漢字及圖片等相關(guān)檢測(cè)技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下

本文實(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ī)號(hào)碼
 *       allphone, 所有手機(jī)號(hào)碼
 *       ydphone, 移動(dòng)手機(jī)號(hào)碼
 *       ltphone, 聯(lián)通手機(jī)號(hào)碼
 *       dxphone, 電信手機(jī)號(hào)碼
 *       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("測(cè)試中文", "cn"); // 判斷中文
 *    如 checkObjectByRegex("測(cè)試中文", null, "^[\u4e00-\u9fa5]+$"); // 自定義表達(dá)式正則
 * @return {boolean}
 */
function checkObjectByRegex(str, cType, regex) {
 /**
  * 定義驗(yàn)證各種格式類型的正則表達(dá)式對(duì)象
  */
 var Regexs = {
  telphone: (/^((\(\d{3}\))|(\d{3}\-))?(\(0\d{2,3}\)|0\d{2,3}-)?[1-9]\d{6,7}$/), //座機(jī)手機(jī)號(hào)碼
  allphone: (/^((13[0-9])|(14[57])|(15[0-9])|(17[678])|(18[0-9]))[0-9]{8}$/),   //所有手機(jī)號(hào)碼
  ydphone: (/^((13[4-9])|(15[012789])|147|178|(18[23478]))[0-9]{8}$/),   //移動(dòng)手機(jī)號(hào)碼
  ltphone: (/^((13[0-2])|(145)|(15[56])|(176)|(18[56]))[0-9]{8}$/),     //聯(lián)通手機(jī)號(hào)碼
  dxphone: (/^((133)|(153)|(177)|(180)|(181)|(189))[0-9]{8}$/),    //電信手機(jī)號(hào)碼
  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)證通過
  // 針對(duì) 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;
  }
  // 針對(duì) 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);
}

希望本文所述對(duì)大家的javascript程序設(shè)計(jì)有所幫助。

相關(guān)文章

  • Echarts.js實(shí)現(xiàn)水滴球和海洋效果

    Echarts.js實(shí)現(xiàn)水滴球和海洋效果

    這篇文章介紹了Echarts.js實(shí)現(xiàn)水滴球和海洋效果的方法,文中通過示例代碼介紹的非常詳細(xì)。對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2022-04-04
  • 查找頁(yè)面中所有類為test的結(jié)點(diǎn)的方法

    查找頁(yè)面中所有類為test的結(jié)點(diǎn)的方法

    這篇文章主要介紹了查找頁(yè)面中所有類為test結(jié)點(diǎn)的方法,需要的朋友可以參考下
    2014-03-03
  • js繼承的6種方式詳解

    js繼承的6種方式詳解

    這篇文章主要給大家介紹了關(guān)于js繼承的6種方式,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-04-04
  • javascript 實(shí)現(xiàn)自由落體的方塊效果

    javascript 實(shí)現(xiàn)自由落體的方塊效果

    這其實(shí)是一個(gè)很簡(jiǎn)單的實(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)粒子矩陣效果

    利用JavaScript實(shí)現(xiàn)3D可旋轉(zhuǎn)粒子矩陣效果

    dat.gui.js是一個(gè)一個(gè)輕量級(jí)的圖形用戶界面庫(kù),或者說GUI組件,只有幾十KB,可以用于創(chuàng)建操作控制三維場(chǎng)景的菜單欄等。本文將利用dat.gui.min.js實(shí)現(xiàn)3D可旋轉(zhuǎn)粒子矩陣效果,感興趣的可以了解一下
    2022-06-06
  • 最簡(jiǎn)單純JavaScript實(shí)現(xiàn)Tab標(biāo)簽頁(yè)切換的方式(推薦)

    最簡(jiǎn)單純JavaScript實(shí)現(xiàn)Tab標(biāo)簽頁(yè)切換的方式(推薦)

    這篇文章主要介紹了最簡(jiǎn)單純JavaScript實(shí)現(xiàn)Tab標(biāo)簽頁(yè)切換的方式(推薦)的相關(guān)資料,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下
    2016-07-07
  • 微信小程序使用image組件顯示圖片的方法【附源碼下載】

    微信小程序使用image組件顯示圖片的方法【附源碼下載】

    這篇文章主要介紹了微信小程序使用image組件顯示圖片的方法,結(jié)合實(shí)例形式簡(jiǎn)單分析了微信小程序附image組件的相關(guān)使用技巧,并附帶源碼供讀者下載參考,需要的朋友可以參考下
    2017-12-12
  • JavaScript中遞歸實(shí)現(xiàn)的方法及其區(qū)別

    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ù)組的方法(小結(jié))

    這篇文章主要介紹了ES6 新增的創(chuàng)建數(shù)組的方法,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-08-08
  • JS實(shí)現(xiàn)評(píng)價(jià)的星星功能

    JS實(shí)現(xiàn)評(píng)價(jià)的星星功能

    這篇文章主要介紹了JS實(shí)現(xiàn)評(píng)價(jià)的星星功能,需要的朋友可以參考下
    2017-08-08

最新評(píng)論