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

工作中比較實(shí)用的JavaScript驗(yàn)證和數(shù)據(jù)處理的干貨(經(jīng)典)

 更新時(shí)間:2016年08月03日 10:08:55   作者:Mr_Smile2014  
工作中比較實(shí)用的JavaScript驗(yàn)證和數(shù)據(jù)處理知識(shí)經(jīng)常會(huì)用到,下面小編通過查閱相關(guān)資料及日常記錄的知識(shí)分享到腳本之家平臺(tái),供大家參考

 在開發(fā)web項(xiàng)目的時(shí)候,難免遇到各種對(duì)網(wǎng)頁數(shù)據(jù)的處理,比如對(duì)用戶在表單中輸入的電話號(hào)碼、郵箱、金額、身份證號(hào)、密碼長(zhǎng)度和復(fù)雜程度等等的驗(yàn)證,以及對(duì)后臺(tái)返回?cái)?shù)據(jù)的格式化比如金額,返回的值為null,還有對(duì)指定日期之前或之后某一天或某一月的計(jì)算。

遇到需要對(duì)數(shù)據(jù)及表單驗(yàn)證的,我相信大家都像我一樣,喜歡在網(wǎng)上找相關(guān)的方法,因?yàn)樽约簩懙脑挘潜容^耗時(shí)的。今天就給大家分享一下,自己在工作中總結(jié)的一些常用
的js。

關(guān)鍵代碼如下所示:

/** 
* 驗(yàn)證密碼復(fù)雜度(必須包含數(shù)字字母) 
* @param str 
* @returns true:滿足規(guī)則,false:不滿足 
*/ 
function validateStr(str){ 
var reg1 = /^(([0-9]{1,})([a-z]{1,}))|(([a-z]{1,})([0-9]{1,}))$/; 
var reg2 = /^(([0-9]{1,})([A-Z]{1,}))|(([A-Z]{1,})([0-9]{1,}))$/; 
//var reg3 = /^([a-zA-Z]{0,})[0-9a-z-A-z]{0,}[~`!@#$%^&*.]{0,}$/; 
str = valueTrim(str); 
//if(reg3.test(str)){ 
// return true; 
//} 
if(reg1.test(str)){ 
return true; 
} 
if(reg2.test(str)){ 
return true; 
} 
return false; 
} 
/** 
* 判斷字符串長(zhǎng)度 必須大于8位小于20位,一般用于密碼 
* @param str 字符串 
* @returns 滿足返回true 
*/ 
function valiDateLength(str){ 
if(str==null || str==''){ 
return false; 
} 
str = valueTrim(str); 
if(parseFloat(str.length)<8 ){ 
return false; 
} 
if(parseFloat(str.length)>20){ 
return false; 
} 
return true; 
} 
/** 
* 驗(yàn)證時(shí)間 
* @param dataValue 格式為:YYYY-MM-DD 
* @returns 匹配返回true 不匹配返回false 
*/ 
function valiDate(dateValue){ 
var result = dateValue.match(/((^((1[8-9]\d{2})|([2-9]\d{3}))(-)(10|12|0?[13578])(-)(3[01]|[12][0-9]|0?[1-9])$)|(^((1[8-9]\d{2})|([2-9]\d{3}))(-)(11|0?[469])(-)(30|[12][0-9]|0?[1-9])$)|(^((1[8-9]\d{2})|([2-9]\d{3}))(-)(0?2)(-)(2[0-8]|1[0-9]|0?[1-9])$)|(^([2468][048]00)(-)(0?2)(-)(29)$)|(^([3579][26]00)(-)(0?2)(-)(29)$)|(^([1][89][0][48])(-)(0?2)(-)(29)$)|(^([2-9][0-9][0][48])(-)(0?2)(-)(29)$)|(^([1][89][2468][048])(-)(0?2)(-)(29)$)|(^([2-9][0-9][2468][048])(-)(0?2)(-)(29)$)|(^([1][89][13579][26])(-)(0?2)(-)(29)$)|(^([2-9][0-9][13579][26])(-)(0?2)(-)(29)$))/); 
if(result==null){ 
return false; 
} 
return true; 
} 
/** 
* 驗(yàn)證電話號(hào)碼 
* @param phoneValue 要驗(yàn)證的電話號(hào)碼 
* @returns 匹配返回true 不匹配返回false 
*/ 
function validatePhone(phoneValue) { 
phoneValue = valueTrim(phoneValue); 
var reg = /^[1][0-9]{10}$/; 
return reg.test(phoneValue); 
} 
/** 
* 驗(yàn)證郵箱 
* @param emailValue 要驗(yàn)證的郵箱 
* @returns 匹配返回true 不匹配返回false 
*/ 
function validateEmail(emailValue){ 
var reg = /^\w+([-+.]\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)*$/; 
return reg.test(emailValue); 
} 
/** 
* 判斷是否是數(shù)字 
* @param numberValue 要驗(yàn)證的數(shù)據(jù) 
* @returns 匹配返回true 不匹配返回false 
*/ 
function isNumber(numberValue){ 
//定義正則表達(dá)式部分 
var reg1 = /^[0-9]{0,}$/; 
var reg2 = /^[1-9]{1}[0-9]{0,}$/; 
//alert(numberValue); 
if(numberValue ==null || numberValue.length==0){ 
return false; 
} 
numberValue = valueTrim(numberValue); 
//判斷當(dāng)數(shù)字只有1位時(shí) 
if(numberValue.length<2){ 
return reg1.test(numberValue); 
} 
return reg2.test(numberValue);; 
} 
/*** 
* 金額 
* @param value 
* @returns 
*/ 
function isMoney(value) { 
if(value==''){ 
return false; 
} 
value = valueTrim(value); 
value = value.replace(/(^\s*)|(\s*$)/g, ""); 
var reg = /^[0-9]*\.?[0-9]{0,2}$/; 
if(isNumber(value)){ 
return true; 
} 
if(value.length>3){ 
if(value.substr(0, 1)=="0"){ 
if(value.substr(3,value.length).length>2){ 
return false; 
} 
} 
} 
return reg.test(value); 
} 
/*** 
* 判斷是否是0到100之間的數(shù) 
* @param value 
* @returns 
*/ 
function isZeroToOne(value) { 
if(value==''){ 
return false; 
} 
value = valueTrim(value); 
if(isMyFloat(value)){ 
if(parseFloat(value)<100 && parseFloat(value)>0){ 
return true; 
} 
} 
return false; 
} 
/** 
* 驗(yàn)證是否是浮點(diǎn)數(shù) 
* @param floatValue 要驗(yàn)證的數(shù)據(jù) 
* @returns 匹配返回true 不匹配返回false 
*/ 
function isMyFloat(floatValue){ 
if(floatValue==''){ 
return false; 
} 
floatValue = valueTrim(floatValue); 
var reg = /^(\d+)(\.\d+)$/; 
if(isNumber(floatValue)){ 
return true; 
} 
if(floatValue.length>3){ 
if(floatValue.substr(0, 1)=="0"){ 
if(floatValue.substr(0, 2)!="0."){ 
return false; 
} 
} 
} 
return reg.test(floatValue); 
} 
/** 
* 判斷是否是漢字 
* @param charValue 要驗(yàn)證的數(shù)據(jù) 
* @returns 匹配返回true 不匹配返回false 
*/ 
function isCharacter(charValue){ 
var reg = /^[\u4e00-\u9fa5]{0,}$/; 
return reg.test(charValue); 
} 
/** 
* 驗(yàn)證座機(jī)號(hào) 
* @param telValue 要驗(yàn)證的座機(jī)號(hào) 
* @returns 匹配返回true 不匹配返回false 
*/ 
function valiDateTel(telValue){ 
var reg = /^(\(\d{3,4}\)|\d{3,4}-)?\d{7,8}$/; 
telValue = valueTrim(telValue); 
if(!reg.test(telValue)){ 
return false; 
} 
return true; 
} 
var Wi = [ 7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2, 1 ]; // 加權(quán)因子 
var ValideCode = [ 1, 0, 10, 9, 8, 7, 6, 5, 4, 3, 2 ]; // 身份證驗(yàn)證位值.10代表X 
/** 
* 驗(yàn)證身份證 
* @param idCard 需要驗(yàn)證的身份證號(hào) 
* @returns 匹配返回true 不匹配返回false 
*/ 
function IdCardValidate(idCardValue) { 
//去掉字符串頭尾空格 
idCardValue = valueTrim(idCardValue.replace(/ /g, "")); 
if (idCardValue.length == 15) { 
//進(jìn)行15位身份證的驗(yàn)證 
return isValidityBrithBy15IdCard(idCardValue); 
} else if (idCardValue.length == 18) { 
// 得到身份證數(shù)組 
var a_idCard = idCardValue.split(""); 
//進(jìn)行18位身份證的基本驗(yàn)證和第18位的驗(yàn)證 
if(isValidityBrithBy18IdCard(idCardValue)&&isTrueValidateCodeBy18IdCard(a_idCard)){ 
return true; 
}else { 
return false; 
} 
} else { 
return false; 
} 
} 
/** 
* 判斷身份證號(hào)碼為18位時(shí)最后的驗(yàn)證位是否正確 
* @param a_idCard 身份證號(hào)碼數(shù)組 
* @return 
*/ 
function isTrueValidateCodeBy18IdCard(a_idCard) { 
var sum = 0; // 聲明加權(quán)求和變量 
if (a_idCard[17].toLowerCase() == 'x') { 
a_idCard[17] = 10;// 將最后位為x的驗(yàn)證碼替換為10方便后續(xù)操作 
} 
for ( var i = 0; i < 17; i++) { 
sum += Wi[i] * a_idCard[i];// 加權(quán)求和 
} 
valCodePosition = sum % 11; // 得到驗(yàn)證碼所位置 
if (a_idCard[17] == ValideCode[valCodePosition]) { 
return true; 
} else { 
return false; 
} 
} 
/** 
* 驗(yàn)證18位數(shù)身份證號(hào)碼中的生日是否是有效生日 
* @param idCard 18位書身份證字符串 
* @return 
*/ 
function isValidityBrithBy18IdCard(idCard18){ 
var year = idCard18.substring(6,10); 
var month = idCard18.substring(10,12); 
var day = idCard18.substring(12,14); 
var temp_date = new Date(year,parseFloat(month)-1,parseFloat(day)); 
// 這里用getFullYear()獲取年份,避免千年蟲問題 
if(temp_date.getFullYear()!=parseFloat(year) 
||temp_date.getMonth()!=parseFloat(month)-1 
||temp_date.getDate()!=parseFloat(day)){ 
return false; 
}else{ 
return true; 
} 
} 
/** 
* 驗(yàn)證15位數(shù)身份證號(hào)碼中的生日是否是有效生日 
* @param idCard15 15位書身份證字符串 
* @return 
*/ 
function isValidityBrithBy15IdCard(idCard15){ 
var year = idCard15.substring(6,8); 
var month = idCard15.substring(8,10); 
var day = idCard15.substring(10,12); 
var temp_date = new Date(year,parseFloat(month)-1,parseFloat(day)); 
// 對(duì)于老身份證中的你年齡則不需考慮千年蟲問題而使用getYear()方法 
if(temp_date.getYear()!=parseFloat(year) 
||temp_date.getMonth()!=parseFloat(month)-1 
||temp_date.getDate()!=parseFloat(day)){ 
return false; 
}else{ 
return true; 
} 
} 
//去掉字符串頭尾空格 
function valueTrim(str) { 
return str.replace(/(^\s*)|(\s*$)/g, ""); 
} 
/** 
* 檢驗(yàn)18位身份證號(hào)碼(15位號(hào)碼可以只檢測(cè)生日是否正確即可,自行解決) 
* @param idCardValue 18位身份證號(hào) 
* @returns 匹配返回true 不匹配返回false 
*/ 
function idCardVildate(cid){ 
var arrExp = [7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2];//加權(quán)因子 
var arrValid = [1, 0, "X", 9, 8, 7, 6, 5, 4, 3, 2];//校驗(yàn)碼 
var reg = /^[1-9]\d{5}[1-9]\d{3}((0\d)|(1[0-2]))(([0|1|2]\d)|3[0-1])\d{3}([0-9]|X)$/; 
if(reg.test(cid)){ 
var sum = 0, idx; 
for(var i = 0; i < cid.length - 1; i++){ 
// 對(duì)前17位數(shù)字與權(quán)值乘積求和 
sum += parseInt(cid.substr(i, 1), 10) * arrExp[i]; 
} 
// 計(jì)算模(固定算法) 
idx = sum % 11; 
// 檢驗(yàn)第18為是否與校驗(yàn)碼相等 
return arrValid[idx] == cid.substr(17, 1).toUpperCase(); 
}else{ 
return false; 
} 
} 
/** 
* 獲取指定日期之前或之后的第幾天 
* 
* @param dayCount 
* 正數(shù)為以后時(shí)間,負(fù)數(shù)為以前時(shí)間 如:1表示為明天,-1為昨天 
* 
*/ 
function getDateStr(dates, dayCount) { 
var dateTime = dayCount * 24 * 60 * 60 * 1000; 
var dd = new Date(); 
if (dates == "") { 
dd = new Date(); 
} else { 
dd = new Date(dates); 
} 
var dateNumber = dd.getTime() + dateTime; 
var newDate = new Date(dateNumber); 
var y = newDate.getFullYear(); 
var m = newDate.getMonth() + 1;// 獲取當(dāng)前月份的日期 
var d = newDate.getDate(); 
if (m < 10) { 
m = "0" + m; 
} 
if (d < 10) { 
d = "0" + d; 
} 
return y + "-" + m + "-" + d; 
} 
/** 
* 獲取指定月份的之前或之后的第幾個(gè)月 
* 
* @param dayCount 
* 正數(shù)為以后月份,負(fù)數(shù)為以前月份 如:1表示為下月,-1為上月 
* 
*/ 
function getMonthStr(dates, monthCount) { 
var dd = new Date(); 
if (dates == "") { 
dd = new Date(); 
} else { 
dd = new Date(dates); 
} 
var y = dd.getFullYear(); 
var m = dd.getMonth() + 1;// 獲取當(dāng)前月份的日期 
m = m + monthCount; 
if (m == 0) { 
m = "12"; 
y = y - 1; 
} else if (m < 10) { 
m = "0" + m; 
} else if (m > 12) { 
m = m - 12; 
m = "0" + m; 
y = y + 1; 
} 
return y + "-" + m; 
} 
/** 
* 
*對(duì)val值為undefined返回“”,否則返回原值 
*/ 
function dealNull(val) { 
if (typeof (val) == "undefined") { 
return ""; 
} else { 
return val; 
} 
} 

以上所述是小編給大家介紹的工作中比較實(shí)用的JavaScript驗(yàn)證和數(shù)據(jù)處理的干貨(經(jīng)典),希望對(duì)大家有所幫助,如果大家有任何疑問請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!

相關(guān)文章

  • 幾種tab切換詳解

    幾種tab切換詳解

    本文主要分享了幾種tab切換的示例代碼。具有很好的參考價(jià)值,下面跟著小編一起來看下吧
    2017-02-02
  • JS實(shí)現(xiàn)具備延時(shí)功能的滑動(dòng)門菜單效果

    JS實(shí)現(xiàn)具備延時(shí)功能的滑動(dòng)門菜單效果

    這篇文章主要介紹了JS實(shí)現(xiàn)具備延時(shí)功能的滑動(dòng)門菜單效果,涉及JavaScript基于鼠標(biāo)事件與時(shí)間函數(shù)實(shí)現(xiàn)頁面樣式延遲變換功能,具有一定參考借鑒價(jià)值,需要的朋友可以參考下
    2015-09-09
  • 詳解js實(shí)現(xiàn)線段交點(diǎn)的三種算法

    詳解js實(shí)現(xiàn)線段交點(diǎn)的三種算法

    下面小編就最近學(xué)會(huì)的一些”求線段交點(diǎn)”的算法說一說, 希望對(duì)大家有所幫助?!扒缶€段交點(diǎn)”是一種非?;A(chǔ)的幾何計(jì)算, 在很多游戲中都會(huì)被使用到。有需要的可以參考學(xué)習(xí)
    2016-08-08
  • 詳解用webpack把我們的業(yè)務(wù)模塊分開打包的方法

    詳解用webpack把我們的業(yè)務(wù)模塊分開打包的方法

    本篇文章主要介紹了用webpack把我們的業(yè)務(wù)模塊分開打包的方法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-07-07
  • 利用Javascript裁剪圖片并存儲(chǔ)的簡(jiǎn)單實(shí)現(xiàn)

    利用Javascript裁剪圖片并存儲(chǔ)的簡(jiǎn)單實(shí)現(xiàn)

    裁剪圖片對(duì)我們來說是再熟悉不過的了,最近工作中就又遇到了這個(gè)需求,所以想著干脆整理下來,方法大家和自己在需要的時(shí)候參考學(xué)習(xí),所以這篇文章主要介紹了利用Javascript裁剪圖片并存儲(chǔ)的簡(jiǎn)單實(shí)現(xiàn),后端PHP處理我用的是THINKPHP框架,需要的朋友可以參考下。
    2017-03-03
  • eval(function(p,a,c,k,e,d)系列解密javascript程序

    eval(function(p,a,c,k,e,d)系列解密javascript程序

    在網(wǎng)上下載源代碼時(shí),很可能發(fā)現(xiàn)代碼里的JS腳本看不懂,這是由于JS加密造成的。如果你發(fā)現(xiàn)JS是以eval(function(p,a,c,k,e,r){e=function(c)開頭的,看到這個(gè)頁面你就可以解決他
    2007-04-04
  • 提高Web性能的前端優(yōu)化技巧總結(jié)

    提高Web性能的前端優(yōu)化技巧總結(jié)

    這篇文章講述可以幫助 改善優(yōu)化前端的技術(shù),非常有用。主要內(nèi)容有清理代碼、壓縮圖片、壓縮外部資源、使用CDN,以及一些其它方法。這些方法會(huì)為你的網(wǎng)站帶顯著的速度提升和整體性能提升。下面跟著小編一起來看下吧
    2017-02-02
  • JS獲取隨機(jī)數(shù)函數(shù)可自定義最小值最大值

    JS獲取隨機(jī)數(shù)函數(shù)可自定義最小值最大值

    這篇文章主要介紹的是一個(gè)JS獲取隨機(jī)數(shù)的函數(shù)可自定義最小值最大值,需要的朋友可以參考下
    2014-05-05
  • 詳解springmvc 接收json對(duì)象的兩種方式

    詳解springmvc 接收json對(duì)象的兩種方式

    本篇文章主要介紹了springmvc 接收json對(duì)象的兩種方式,具有一定的參考價(jià)值,有需要的可以了解一下。
    2016-12-12
  • 微信小程序?qū)崿F(xiàn)長(zhǎng)按刪除圖片的示例

    微信小程序?qū)崿F(xiàn)長(zhǎng)按刪除圖片的示例

    本篇文章主要介紹了微信小程序?qū)崿F(xiàn)長(zhǎng)按刪除圖片的示例,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2018-05-05

最新評(píng)論