博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
JS验证只能输入数字,数字和字母等的正则表达式
阅读量:6501 次
发布时间:2019-06-24

本文共 9025 字,大约阅读时间需要 30 分钟。

JS判断只能是数字和小数点 

0.不能输入中文
1)<input οnpaste="return false;" type="text" name="textfield" style="width:400px; ime-mode:disabled" value="">
2)<script>
function chkIt(frm){
  if (frm.n1.value.length>0&&frm.n1.value.match(/[\x01-\xFF]*/)==false){
    alert('n1不能输入中文!')
    frm.n1.focus();
    return false;
  }
}
</script>
<body>
<form οnsubmit="return chkIt(this)">
<input name="n1">
<input name="n2">
<input name="smt" type="submit" value="提交">
</form>
</body>

1.文本框只能输入数字代码(小数点也不能输入) 

<input οnkeyup="this.value=this.value.replace(/\D/g,'')" onafterpaste="this.value=this.value.replace(/\D/g,'')"> 
2.只能输入数字,能输小数点. 
<input οnkeyup="if(isNaN(value))execCommand('undo')" onafterpaste="if(isNaN(value))execCommand('undo')"> 
<input name=txt1 οnchange="if(/\D/.test(this.value)){alert('只能输入数字');this.value='';}"> 
3.数字和小数点方法二 
<input type=text t_value="" o_value="" οnkeypress="if(!this.value.match(/^[\+\-]?\d*?\.?\d*?$/))this.value=this.t_value;else this.t_value=this.value;if(this.value.match(/^(?:[\+\-]?\d+(?:\.\d+)?)?$/))this.o_value=this.value" οnkeyup="if(!this.value.match(/^[\+\-]?\d*?\.?\d*?$/))this.value=this.t_value;else this.t_value=this.value;if(this.value.match(/^(?:[\+\-]?\d+(?:\.\d+)?)?$/))this.o_value=this.value" οnblur="if(!this.value.match(/^(?:[\+\-]?\d+(?:\.\d+)?|\.\d*?)?$/))this.value=this.o_value;else{if(this.value.match(/^\.\d+$/))this.value=0+this.value;if(this.value.match(/^\.$/))this.value=0;this.o_value=this.value}"> 
4.只能输入字母和汉字 
<input οnkeyup="value=value.replace(/[\d]/g,'') "onbeforepaste="clipboardData.setData('text',clipboardData.getData('text').replace(/[\d]/g,''))" maxlength=10 name="Numbers"> 
5.只能输入英文字母和数字,不能输入中文 
<input οnkeyup="value=value.replace(/[^\w\.\/]/ig,'')"> 
6.只能输入数字和英文<font color="Red">chun</font> 
<input onKeyUp="value=value.replace(/[^\d|chun]/g,'')"> 
7.小数点后只能有最多两位(数字,中文都可输入),不能输入字母和运算符号: 
<input onKeyPress="if((event.keyCode<48 || event.keyCode>57) && event.keyCode!=46 || /\.\d\d$/.test(value))event.returnValue=false"> 
8.小数点后只能有最多两位(数字,字母,中文都可输入),可以输入运算符号:

<input οnkeyup="this.value=this.value.replace(/^(\-)*(\d+)\.(\d\d).*$/,'$1$2.$3')">

禁止特殊字符:

 

onKeyPress="if(event.keyCode < 45 || event.keyCode > 57 ) event.returnValue = false;"

 

只能输入汉字:

<input οnkeyup="value=value.replace(/[^/u4E00-/u9FA5]/g,'')" onbeforepaste="clipboardData.setData('text',clipboardData.getData('text').replace(/[^/u4E00-/u9FA5]/g,''))">

style="ime-mode:disabled"禁止汉字输入法

只能输入数字:

<input οnkeyup="value=value.replace(/[^/d]/g,'') "onbeforepaste="clipboardData.setData('text',clipboardData.getData('text').replace(/[^/d]/g,''))">

只能输入英文和数字:
<input οnkeyup="value=value.replace(/[/W]/g,'') "onbeforepaste="clipboardData.setData('text',clipboardData.getData('text').replace(/[^/d]/g,''))">

控制输入框只能输入文字或数字,也可以不允许输入特殊字符

这里不允许输入如下字符: (像 ^&* 等)<br>
<textarea rows=2 cols=20 name=comments onKeypress="if ((event.keyCode > 32 && event.keyCode < 48) || (event.keyCode > 57 && event.keyCode < 65) || (event.keyCode > 90 && event.keyCode < 97)) event.returnValue = false;">

只禁止空格输入

οnkeyup="value=value.replace(//s/g,'')"

οnkeydοwn="if(event.keyCode==32) return false"

只能输入中文和英文:

οnkeyup="value=value.replace(/[^/a-zA-Z/u4E00-/u9FA5]/g,'')" onbeforepaste="clipboardData.setData('text',clipboardData.getData('text').replace(/[^/a-zA-Z/u4E00-/u9FA5]/g,''))"

 

不允许输入特殊字符和空格:

<input id="code" οnkeypress="return ValidateSpecialCharacter();" οnblur="validate(this)"/>

 

————————————————————————————————————————

 不能为空

<input οnblur="if(this.value.replace(/^ +| +$/g,'')=='')alert('不能为空!')">

判断字符由字母和数字,下划线,点号组成.且开头的只能是下划线和字母

/^([a-zA-z_]{1})([\w]*)$/g.test(str)

只能输入数字

<input name="text" type="text" id="NewPage" onKeyUp="value=value.replace(/\D/g,'')" onafterpaste="value=value.replace(/\D/g,'')" >

只能输入中文

<input type="text" οnkeyup="value=value.replace(/[^\u4E00-\u9FA5]/g,'')">

只能输入英文

<input type="text" οnkeyup="value=value.replace(/[^\a-\z\A-\Z]/g,'')">
<input type="text" οnkeyup="value=value.replace(/[^a-zA-Z]/g,'')">

 --------------------------------------------------------------------------------------------------------------------

1.文本框只能输入数字代码(小数点也不能输入)

<input οnkeyup="this.value=this.value.replace(//D/g,'')" onafterpaste="this.value=this.value.replace(//D/g,'')">

2.只能输入数字,能输小数点.

<input οnkeyup="if(isNaN(value))execCommand('undo')" onafterpaste="if(isNaN(value))execCommand('undo')">
<input name=txt1 οnchange="if(//D/.test(this.value)){alert('只能输入数字');this.value='';}">

3.数字和小数点方法二

<input type=text t_value="" o_value="" οnkeypress="if(!this.value.match(/^[/+/-]?/d*?/.?/d*?$/))this.value=this.t_value;else this.t_value=this.value;if(this.value.match(/^(?:[/+/-]?/d+(?:/./d+)?)?$/))this.o_value=this.value" οnkeyup="if(!this.value.match(/^[/+/-]?/d*?/.?/d*?$/))this.value=this.t_value;else this.t_value=this.value;if(this.value.match(/^(?:[/+/-]?/d+(?:/./d+)?)?$/))this.o_value=this.value" οnblur="if(!this.value.match(/^(?:[/+/-]?/d+(?:/./d+)?|/./d*?)?$/))this.value=this.o_value;else{if(this.value.match(/^/./d+$/))this.value=0+this.value;if(this.value.match(/^/.$/))this.value=0;this.o_value=this.value}">

4.只能输入字母和汉字

<input οnkeyup="value=value.replace(/[/d]/g,'') "onbeforepaste="clipboardData.setData('text',clipboardData.getData('text').replace(/[/d]/g,''))" maxlength=10 name="Numbers">

5.只能输入英文字母和数字,不能输入中文

<input οnkeyup="value=value.replace(/[^/w/.//]/ig,'')">

6.只能输入数字和英文<font color="Red">chun</font>

<input onKeyUp="value=value.replace(/[^/d|chun]/g,'')">

7.小数点后只能有最多两位(数字,中文都可输入),不能输入字母和运算符号:

<input onKeyPress="if((event.keyCode<48 || event.keyCode>57) && event.keyCode!=46 || //./d/d$/.test(value))event.returnValue=false">

8.小数点后只能有最多两位(数字,字母,中文都可输入),可以输入运算符号:

<input οnkeyup="this.value=this.value.replace(/^(/-)*(/d+)/.(/d/d).*$/,'$1$2.$3')">

 

只能输入中文、英文、数字、@符号和.符号

<input type="text" οnkeyup="value=value.replace(/[^\a-\z\A-\Z0-9\u4E00-\u9FA5\@\.]/g,'')">

只允许输入英文,且不能粘贴也无法弹出粘贴菜单

<input type="text" οnkeyup="value=value.replace(/[^\a-\z\A-\Z]/g,'')" οnkeydοwn="fncKeyStop(event)" οnpaste="return false" oncontextmenu = "return false"/>

只能输入数字和点号(注意:在[^\d\.]里的d不能写成大写D,否则就变成除了数字以外的所有字符)

<input name="price" type="text" size="8" maxlength="8" οnkeyup="value=value.replace(/[^\d\.]/g,'')" >

总而言之:先在<input>里输入οnkeyup="value=value.replace(/[^\X]/g,'')" 然后在(/[\X]/g,'')里的X换成你想输入的代码就可以了

中文:u4E00-u9FA5

数字:d、0-9
英文:a-z、A-Z
其它符号@,点或其它符号.也可以多个,用\隔开就行了.
例如:
中、英文和数字加@符号加点符号:\a-\z\A-\Z0-9\u4E00-\u9FA5\@\.

若 想在文本框里不能右键弹出菜单和不能粘贴进复制的信息的话就要在<input>里输入 onKeyDown="fncKeyStop(event)" οnpaste="return false" οncοntextmenu="return false;"

---------------------------------------------------------------------------------------------------------------------------------------

 

 

 

 

其一,只允许输入数字和小数点。 

<input onKeypress="return (/[/d.]/.test(String.fromCharCode(event.keyCode)))" style="ime-mode:Disabled"> 
其二,判断的更详细一些,甚至22..2这样不算数字也判断得出来 
<script> 
function check(){ 
if (isNaN(tt.value)) 
{alert("非法字符!"); 
tt.value="";} 
</script> 
<input type="text" name="tt" οnkeyup="check();"> 
其三,只允许输入整数。其实也完全可以根据第三条来举一反三做一些限制。 
<script language=javascript> 
function onlyNum() 
if(!(event.keyCode==46)&&!(event.keyCode==8)&&!(event.keyCode==37)&&!(event.keyCode==39)) 
if(!((event.keyCode>=48&&event.keyCode<=57)||(event.keyCode>=96&&event.keyCode<=105))) 
event.returnValue=false; 
</script><input οnkeydοwn="onlyNum();" style="ime-mode:Disabled> 
结语,其实 
style="ime-mode:Disabled 
这句是比较实用的。意为关闭输入法。省得有些人开着全角输入数字,结果输入不进去来找你哭天抹泪的,还怪你设计的不好。 
只允许输入数字 
<input name="username" type="text" οnkeyup="value=this.value.replace(//D+/g,'')"> 
只允许输入英文字母、数字和下划线(以下二种方法实现) 
<input name="userna其一,只允许输入数字和小数点。 
<input onKeypress="return (/[/d.]/.test(String.fromCharCode(event.keyCode)))" style="ime-mode:Disabled"> 
其二,判断的更详细一些,甚至22..2这样不算数字也判断得出来 
<script> 
function check(){ 
if (isNaN(tt.value)) 
{alert("非法字符!"); 
tt.value="";} 
</script> 
<input type="text" name="tt" οnkeyup="check();"> 
其三,只允许输入整数。其实也完全可以根据第三条来举一反三做一些限制。 
<script language=javascript> 
function onlyNum() 
if(!(event.keyCode==46)&&!(event.keyCode==8)&&!(event.keyCode==37)&&!(event.keyCode==39)) 
if(!((event.keyCode>=48&&event.keyCode<=57)||(event.keyCode>=96&&event.keyCode<=105))) 
event.returnValue=false; 
</script><input οnkeydοwn="onlyNum();" style="ime-mode:Disabled> 
结语,其实 
style="ime-mode:Disabled 
这句是比较实用的。意为关闭输入法。省得有些人开着全角输入数字,结果输入不进去来找你哭天抹泪的,还怪你设计的不好。 
只允许输入数字 
<input name="username" type="text" οnkeyup="value=this.value.replace(//D+/g,'')"> 
只允许输入英文字母、数字和下划线(以下二种方法实现) 
<input name="username" type="text" style="ime-mode:disabled"> 
<input name="username" type="text" οnkeyup="value=value.replace(/[^/w/.//]/ig,'')"> 
只允许输入英文字母、数字和&=@ 
<input name="username" type="text" οnkeyup="value=value.replace(/[^/w=@&]|_/ig,'')"> 
只允许输入汉字 
<input name="username" type="text" οnkeyup="value=value.replace(/[^/u4E00-/u9FA5]/g,'')"> 
me" type="text" style="ime-mode:disabled"> 
<input name="username" type="text" οnkeyup="value=value.replace(/[^/w/.//]/ig,'')"> 
只允许输入英文字母、数字和&=@ 
<input name="username" type="text" οnkeyup="value=value.replace(/[^/w=@&]|_/ig,'')"> 
只允许输入汉字 
<input name="username" type="text" οnkeyup="value=value.replace(/[^/u4E00-/u9FA5]/g,'')">

转载于:https://www.cnblogs.com/FengleQin/p/5983423.html

你可能感兴趣的文章
设置应用图标badge(徽章)
查看>>
ORACLE SQL: 经典查询练手第二篇
查看>>
运动目标检测ViBe算法
查看>>
MySQL基本概念
查看>>
推荐两款简单好用的图片放大jquery插件
查看>>
Java实现MD5(32/16位大小写)加密
查看>>
[emuch.net]MatrixComputations(1-6)
查看>>
zencart安全辅助小脚本
查看>>
alter system switch logfile与alter system archive log current的区别
查看>>
第十周项目5:贪心的富翁
查看>>
利用SurfaceView显示正弦曲线,仿造示波器
查看>>
scala学习手记34 - trait方法的延迟绑定
查看>>
centos 7 部署k8s集群
查看>>
Android开发之SharedPreferences的封装
查看>>
第36章 网络管理
查看>>
VPC见解
查看>>
Maven内置变量
查看>>
PARAMETERS 指令
查看>>
jquery日历插件FullCalendar使用技巧
查看>>
node.js写一个json服务
查看>>