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

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)文章

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

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

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

    查找頁面中所有類為test的結(jié)點的方法

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

    js繼承的6種方式詳解

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

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

    這其實是一個很簡單的實現(xiàn),create一個新的div元素,然后append到文檔的body上,經(jīng)過一定時間的延遲,做自由落體運動,著地后fade消失。 不多說,直接上代碼。
    2010-01-01
  • 利用JavaScript實現(xiàn)3D可旋轉(zhuǎ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標簽頁切換的方式(推薦)

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

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

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

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

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

    JS實現(xiàn)評價的星星功能

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

最新評論