常用校验js

[color=blue]/**
* 常用校验JS
*
* @author LJ
*
*/

//****************************************************************************************************************

/**
* input 输入框校验说明
* maxlength="11" 表示最大输入长度
* style="ime-mode:disabled;" 表示不能切换输入法
* οnpaste="return false;" 表示不能粘贴
*
* <input type="text" style="ime-mode:disabled;" οnpaste="return false;" maxlength="11" οnkeyup="onlyIntNum(this)" />
*/

//****************************************************************************************************************


/**
* 只允许输入数字
* <input type="text" οnkeyup="onlyIntNum(this)" />
*/
function onlyIntNum(obj){
obj.value = obj.value.replace(/[^\d]/g,""); //先把非数字的都替换掉
};


/**
* 只允许输入数字和小数点(不包括负数)
* <input type="text" οnkeyup="onlyNum(this)" />
*/
function onlyNum(obj) {
obj.value = obj.value.replace(/[^\d.]/g,""); //先把非数字的都替换掉,除了数字和.
obj.value = obj.value.replace(/^\./g,""); //必须保证第一个为数字而不是.
obj.value = obj.value.replace(/\.{2,}/g,"."); //保证只有出现一个.而没有多个.
obj.value = obj.value.replace(".","$#$").replace(/\./g,"").replace("$#$","."); //保证.只出现一次,而不能出现两次以上
};

/**
* 只允许输入数字和小数点(包括负数)
* <input type="text" οnkeyup="onlyNum(this,event)" />
*/
function onlyNum(obj,event) {
//响应鼠标事件,允许左右方向键移动
event = window.event || event;
if (event.keyCode == 37 | event.keyCode == 39) {
return;
}
var t = obj.value.charAt(0);
//先把非数字的都替换掉,除了数字和.
obj.value = obj.value.replace(/[^\d.]/g, "");
//必须保证第一个为数字而不是.
obj.value = obj.value.replace(/^\./g, "");
//保证只有出现一个.而没有多个.
obj.value = obj.value.replace(/\.{2,}/g, ".");
//保证.只出现一次,而不能出现两次以上
obj.value = obj.value.replace(".", "$#$").replace(/\./g, "").replace("$#$", ".");
//如果第一位是负号,则允许添加 如果不允许添加负号 可以把这块注释掉
if (t == '-') {
obj.value = '-' + obj.value;
}
};


/**
* 只允许输入数字或字母
* <input type="text" οnkeyup="onlyNumOrLetter(this)" />
*/
function onlyNumOrLetter(obj) {
obj.value = obj.value.replace( /[^\w\.\/]/ig,"");
};
/**
* 只允许输入字母
* <input type="text" οnkeyup="onlyLetter(this)" />
*/
function onlyLetter(obj) {
obj.value = obj.value.replace(/[^\a-\z\A-\Z]/g,"");
};

/**
* 只能输入中文、英文、数字、小数点
* <input type="text" οnkeyup="onlyNumOrLetterOrChinese(this)" />
*/
function onlyNumOrLetterOrChinese(obj) {
obj.value = obj.value.replace(/[^\a-\z\A-\Z0-9\u4E00-\u9FA5\.]/g,"");
};

/**
* 只能输入中文
* <input type="text" οnkeyup="onlyChinese(this)" />
*/
function onlyChinese(obj) {
obj.value = obj.value.replace(/[^\u4E00-\u9FA5]/g,''); ;
};

/**
* 只能输入英文、数字、下划线
* <input type="text" οnkeyup="onlyNumOrLetterOr_(this)" />
*/
function onlyNumOrLetterOr_(obj) {
obj.value = obj.value.replace(/[^\w\.\/]/ig,'');
};

/**
* 只能输入英文、数字、特殊符号 =@#!$%&.*_
* <input type="text" οnkeyup="onlyNumOrLetterOrSign(this)" />
*/
function onlyNumOrLetterOrSign(obj) {
obj.value = obj.value.replace(/[^\w=@#!$%&.*_]|/ig,'');
};


//****************************************************************************************************************

/**
* 常用正则校验
*
*/

//****************************************************************************************************************

/**
*正则校验
*repl 正则表达式
*str 要校验字符串
*/
function checkRepl(repl,str){
if(repl.test(str)){
return true;
}else{
return false;
}
}

/**
* 手机号校验
*/
function checkMobile(str) {
var repl = /^1[3|4|5|7|8][0-9]\d{4,8}$/;
if(repl.test(str)){
return true;
}else{
return false;
}
}

/**
* 邮箱校验
*/
function checkEmail(str){
var repl = /^(\w-*\.*)+@(\w-?)+(\.\w{2,})+$/;
if(repl.test(str)){
return true;
}else{
return false;
}
}

/**
* 身份证校验
*/
function checkCardId(str){
var repl = /^[1-9]\d{7}((0\d)|(1[0-2]))(([0|1|2]\d)|3[0-1])\d{3}$|^[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(repl.test(str)){
return true;
}else{
return false;
}
}



[/color]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值