JS判断数字/字母/中文

1.过滤特殊字符:
var reg = /^(\w|[\u4E00-\u9FA5])*$/;
if(username.match(reg))
{
  return ture;
}
else
{
 alert("用户名只允许为英文,数字和汉字的混合,\n请检查是否前后有空格或者其他符号");
  return false;
}

2.利用正则表达式限制网页表单里的文本框输入内容:
用正则表达式限制只能输入中文:οnkeyup="value=value.replace(/[^\u4E00-\u9FA5]/g,'')"
onbeforepaste="clipboardData.setData('text',clipboardData.getData('text').replace(/[^\u4E00-\u9FA5]/g,''))"

用正则表达式限制只能输入全角字符:οnkeyup="value=value.replace(/[^\uFF00-\uFFFF]/g,'')"
onbeforepaste="clipboardData.setData('text',clipboardData.getData('text').replace(/[^\uFF00-\uFFFF]/g,''))"

用正则表达式限制只能输入数字:οnkeyup="value=value.replace([^\d]/g,'')"
onbeforepaste="clipboardData.setData('text',clipboardData.getData('text').replace(/[^\d]/g,''))"

用正则表达式限制只能输入数字和英文:οnkeyup="value=value.replace(/[\W]/g,'')"
onbeforepaste="clipboardData.setData('text',clipboardData.getData('text').replace(/[^\d]/g,''))"

数字 if(!isNaN(document.all.form.str.value)) {alert("数字");}
字母 var str = /[_a-zA-Z]/;if(str.test(document.all.form.str.value)) { alert("字母");}

* Trim 删除首位空格
* Occurs 统计指定字符出现的次数
* isDigit 检查是否由数字组成
* isAlpha 检查是否由数字字母和下划线组成
* isNumber 检查是否为数
* lenb 返回字节数
* isInChinese 检查是否包含汉字
* isEmail 简单的email检查
* isDate 简单的日期检查,成功返回日期对象
* isInList 检查是否有列表中的字符字符
* isInList 检查是否有列表中的字符字符

String.prototype.Trim = function()
{
  return this.replace(/(^\s*)|(\s*$)/g, "");
}

String.prototype.Occurs = function(ch)
{
 // var re = eval_r("/[^"+ch+"]/g");
 // return this.replace(re, "").length;
 return this.split(ch).length-1;
}

String.prototype.isDigit = function()
{
  var s = this.Trim();
  return (s.replace(/\d/g, "").length == 0);
}

String.prototype.isAlpha = function()
{
  return (this.replace(/\w/g, "").length ==0);
}

String.prototype.isNumber = function()
{
  var s = this.Trim();
  return (s.search(/^[+-]?[0-9.]*$/)>= 0);
}

String.prototype.lenb = function()
{
  returnthis.replace(/[^\x00-\xff]/g,"**").length;
}

String.prototype.isInChinese = function()
{
  return (this.length !=this.replace(/[^\x00-\xff]/g,"**").length);
}

String.prototype.isEmail = function()
{
 var strr;
  var mail = this;
 var re = /(\w+@\w+\.\w+)(\.{0,1}\w*)(\.{0,1}\w*)/i;
 re.exec(mail);
 if(RegExp.$3!="" &&RegExp.$3!="." &&RegExp.$2!=".")
    strr =RegExp.$1+RegExp.$2+RegExp.$3;
 else
  if(RegExp.$2!="" &&RegExp.$2!=".")
     strr = RegExp.$1+RegExp.$2;
  else
     strr =RegExp.$1;
 return (strr==mail);
}

String.prototype.isDate = function()
{
  var p;
  var re1 =/(\d{4})[年./-](\d{1,2})[月./-](\d{1,2})[日]?$/;
  var re2 =/(\d{1,2})[月./-](\d{1,2})[日./-](\d{2})[年]?$/;
  var re3 =/(\d{1,2})[月./-](\d{1,2})[日./-](\d{4})[年]?$/;
  if(re1.test(this)) {
  p = re1.exec(this);
  return new Date(p[1],p[2],p[3]);
  }
  if(re2.test(this)) {
  p = re2.exec(this);
  return new Date(p[3],p[1],p[2]);
  }
  if(re3.test(this)) {
  p = re3.exec(this);
  return new Date(p[3],p[1],p[2]);
  }
  return false;
}

String.prototype.isInList = function(list)
{
  var re = eval_r("/["+list+"]/");
  return re.test(this);
}

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值