js 各种验证与功能代码

/**
 * 目录
 * verifyPhone			验证手机号码
 * verifyPostbox		验证邮箱地址
 * verifyqqNum			验证QQ号码
 * verifyWeChat			验证微信号码
 * verifyPwIntensity            验证密码强度
 * cbodataByID			绑定下拉框
 * timestampToTime		时间戳转换成日期格式
 */

1、下列验证方法的使用:使用onchange事件(当input捕获到焦点后,系统储存当前值,然后input焦点离开后判断当前值与储存的值是否不等,为true时触发事件) 

HTML:<input type="text" class="input-text" id="operCellphone" name="operCellphone" title="手机号码" onchange="verifyPhone(this)">

(1)、verifyPhone - 验证手机号码

/**
 * 验证手机号码
 * @param phone 手机号码
 * @returns {Boolean} {false:正确,true:出错}
 */
function verifyPhone (obj) {
    var id = $(obj).attr("id");//获取id
    var phone = $.trim($("#" + id).val());//获取输入的值
    if (phone != "" && phone.length > 0) {
        if (/^[0-9]+$/.test(phone)) {
            if (/^134[0-8]\d{7}|((13([0-3]|[5-9]))|149|15([0-3]|[5-9])|166|17(3|[5-8])|18[0-9]|19[8-9])\d{8}$/.test(phone)) {
                return;//返回,结束函数
            }
        }
    }
    $("#" + id).val("");//条件不符时,使input内容为空
}

(2)、verifyPostbox - 验证邮箱地址

/**
 * 验证邮箱地址
 * @param postbox 邮箱地址
 * @returns {Boolean} {false:正确,true:出错}
 */
function verifyPostbox (obj) {
	var id = $(obj).attr("id");//获取id
	var postbox = $.trim($("#" + id).val());//获取输入的值
	if (postbox != "" && postbox.length > 0) {
		if (/^\w+((-\w+)|(\.\w+))*\@[A-Za-z0-9]+((\.|-)[A-Za-z0-9]+)*\.[A-Za-z0-9]+$/.test(postbox)) {
			return;//返回,结束函数
		}
	}
	$("#" + id).val("");//条件不符时,使input内容为空
}

(3)、verifyqqNums - 验证QQ号码

/**
 * 验证QQ号码
 * @param qqNum QQ号码
 * @returns {Boolean} {false:正确,true:出错}
 */
function verifyqqNums (obj) {
	var id = $(obj).attr("id");//获取id
	var qqNum = $.trim($("#" + id).val());//获取输入的值
	if (qqNum != "" && qqNum.length > 0) {
		if (/^[1-9][0-9]{5,10}$/.test(qqNum)) {
			return;//返回,结束函数
		}
	}
	$("#" + id).val("");//条件不符时,使input内容为空
}

 (4)、verifyWeChat - 验证微信号码

/**
 * 验证微信号码
 * @param wechat 微信号码
 * @returns {Boolean} {false:正确,true:出错}
 */
function verifyWeChat (obj) {
	var id = $(obj).attr("id");//获取id
	var wechat = $.trim($("#" + id).val());//获取输入的值
	if (wechat != "" && wechat.length > 0) {
		if (/^[a-zA-Z][a-zA-Z0-9_-]{5,19}$/.test(wechat)) {
			return;//返回,结束函数
		}
	}
	$("#" + id).val("");//条件不符时,使input内容为空
}

 (5)、verifyPwIntensity - 验证密码强度

/**
 * 验证密码强度
 * @param pw 密码
 * @returns {Number} {0:密码包含特殊字符-强,1:密码长度小于6,大于20,2:密码全部为正整数且长度小于9-弱,3:密码全部为正整数,长度大于9-中,4:密码包含字母-中}
 */
function verifyPwIntensity (pw) {
	if (pw != "" && pw.length > 0) {//判断是否为空,长度是否为0
		if (/^.{6,20}$/.test(pw)) {
			if (!/^\d+$/.test(pw)) {
			    if (/^[a-z0-9A-Z]+$/.test(pw)) {
			        return 4;//密码包含字母-中
			    }
			} else {
			    if (pw.length < 9) return 2;//密码全部为正整数且长度小于9-弱
			    else return 3;//密码全部为正整数,长度大于9-中
			}
		}
		else return 1;//密码长度小于6,大于20
	}
	return 0;//密码包含特殊字符-强
}

2、绑定下拉框是使用$.each()对查询出的json结构的数组进行遍历 

/**
 * 绑定下拉框
 * @param url
 * @param id
 */
function cbodataByID(url, id) {
    $.post(url, function (data) {
        $.each(data.list, function (i) {
            $('<option></option>').val(data.list[i].typeId).text(data.list[i].type).appendTo($("#" + id));
        });
    });
};
/**
 * 修改回填绑定下拉框
 * selectLoadDataes(selectId, url, k)
 * selectLoadDataes("list", "${ctx}/xxx.do", "1")
 */
function selectLoadDataes(selectId, url, k) {
    $.post(url, function (data) {
        $.each(data.list, function (i) {
            $('<option></option>').val(data.list[i].typeId).text(data.list[i].type).appendTo($("#" + selectId));
        });
        $("#" + selectId).val(k);
    });
}

3、timestampToTime()方法用于在js中对数据库查询出的时间戳进行变化成正常的时间格式(yyyy-MM-dd HH:mm:ss)

/**
 * 时间戳转换成日期格式
 * @param timestamp 毫秒级别的时间戳
 * @returns {String} {1544489962000:2018-12-11 8:59:22}
 */
function timestampToTime(timestamp) {
    var date = new Date(timestamp);//时间戳为10位需*1000,时间戳为13位的话不需乘1000
    var Y = date.getFullYear() + '-';//2018-
    var M = (date.getMonth()+1 < 10 ? '0'+(date.getMonth()+1) : date.getMonth()+1) + '-';//12-
    var D = (date.getDate().toString().length < 2 ? '0'+date.getDate() : date.getDate()) + ' ';//11 
    var h = (date.getHours().toString().length < 2 ? '0'+date.getHours() : date.getHours()) + ':';//8:
    var m = (date.getMinutes().toString().length < 2 ? '0'+date.getMinutes() : date.getMinutes()) + ':';//59:
    var s = (date.getSeconds().toString().length < 2 ? '0'+date.getSeconds() : date.getSeconds());//22
    return Y+M+D+h+m+s;
}

 

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值