js正則表達式:驗證郵箱格式、密碼復雜度、手機號碼、QQ號碼
<script type="text/javascript">
$(function () {
$("input[name='sub']").on("click", function () {
if (!isEmail($("input[name='email']").val())) {
$("span[name='email']").html("郵箱格式錯誤");
return false;
}
else {
$("span[name='email']").html("");
}
if (checkStrong($("input[name='password']").val()) < 3) {
$("span[name='password']").html("密碼太過簡單");
return false;
}
else {
$("span[name='password']").html("");
}
if (!isQQ($.trim($("input[name='qq']").val()))) {
$("span[name='qq']").html("請輸入正確的QQ號碼");
return false;
}
else {
$("span[name='qq']").html("");
}
if (!isPhone($.trim($("input[name='mnumber']").val()))) {
$("span[name='mnumber']").html("請輸入正確的手機號碼");
return false;
}
else {
$("span[name='mnumber']").html("");
}
return true;
});
});
/**
* 檢查字符串是否為合法QQ號碼
* @param {String} 字符串
* @return {bool} 是否為合法QQ號碼
*/
function isQQ(aQQ) {
var bValidate = RegExp(/^[1-9][0-9]{4,9}$/).test(aQQ);
if (bValidate) {
return true;
}
else
return false;
}
/**
* 檢查字符串是否為合法手機號碼
* @param {String} 字符串
* @return {bool} 是否為合法手機號碼
*/
function isPhone(aPhone) {
var bValidate = RegExp(/^(0|86|17951)?(13[0-9]|15[012356789]|18[0-9]|14[57])[0-9]{8}$/).test(aPhone);
if (bValidate) {
return true;
}
else
return false;
}
/**
* 檢查字符串是否為合法email地址
* @param {String} 字符串
* @return {bool} 是否為合法email地址
*/
function isEmail(aEmail) {
var bValidate = RegExp(/^\w+((-\w+)|(\.\w+))*\@[A-Za-z0-9]+((\.|-)[A-Za-z0-9]+)*\.[A-Za-z0-9]+$/).test(aEmail);
if (bValidate) {
return true;
}
else
return false;
}
/**
* 檢查字符串是否是整數
* @param {String} 字符串
* @return {bool} 是否是整數
*/
function isInteger(s) {
var isInteger = RegExp(/^[0-9]+$/);
return (isInteger.test(s));
}
/*
判斷字符類型
*/
function CharMode(iN) {
if (iN >= 48 && iN <= 57) //數字
return 1;
if (iN >= 65 && iN <= 90) //大寫字母
return 2;
if (iN >= 97 && iN <= 122) //小寫
return 4;
else
return 8; //特殊字符
}
/*
統計字符類型
*/
function bitTotal(num) {
modes = 0;
for (i = 0; i < 4; i++) {
if (num & 1) modes++;
num >>>= 1;
}
return modes;
}
/*
返回密碼的強度級別
*/
function checkStrong(sPW) {
if (sPW.length <= 4)
return 0; //密碼太短
Modes = 0;
for (i = 0; i < sPW.length; i++) {
//測試每一個字符的類別并統計一共有多少種模式.
Modes |= CharMode(sPW.charCodeAt(i));
}
return bitTotal(Modes);
}
</script></pre>
本文由用戶 jopen 自行上傳分享,僅供網友學習交流。所有權歸原作者,若您的權利被侵害,請聯系管理員。
轉載本站原創文章,請注明出處,并保留原始鏈接、圖片水印。
本站是一個以用戶分享為主的開源技術平臺,歡迎各類分享!