function inp(obj){
var regStrs = [
['^0(\\d+)', '$1'], //禁止录入整数部分两位以上,但首位为0
['[^0-9\]', ''] //禁止录入任何非数字和点
];
for(i=0; i<regStrs.length; i++){
var reg = new RegExp(regStrs[i][0]);
obj.value = obj.value.replace(reg, regStrs[i][1]);
}
}
<input name="" type="text" value="" onKeyUp="inp(this)">
7 个解决方案
#1
但是用键盘左右键的时候,一直跳到文字的最后
完全不明白这句话的意思
完全不明白这句话的意思
#2
var _value = "";
function inp(obj){
if(_value==obj.value) return;
var regStrs = [
['^0(\\d+)', '$1'], //禁止录入整数部分两位以上,但首位为0
['[^0-9\]', ''] //禁止录入任何非数字和点
];
for(i=0; i<regStrs.length; i++){
var reg = new RegExp(regStrs[i][0],"g");
obj.value = obj.value.replace(reg, regStrs[i][1]);
}
_value = obj.value;
}
#3
要想光标一直在最后 可以先清空 在重新赋值就是在最后了
var obj=document.getElementById("testId");
var val=obj.value;
//obj.focus();
bj.value="";
obj.value=val;
var obj=document.getElementById("testId");
var val=obj.value;
//obj.focus();
bj.value="";
obj.value=val;
#4
当按左键键盘弹起的时候,又从新判断一下文本框中的值,它当然会跳到文字的最后,和你输入东西一样的效果
#6
//原因是因为每按一下键盘都触发正则,并对输入框赋值,所以光标老是跑到最后。(FF不会)
//解决方法:判断输入框的值有没有变化才触发正则替换。
<input name="" type="text" value="" onKeyUp="inp(this)">
<script type="text/javascript">
var v="";
function inp(obj){
if(obj.value!=v){
v=obj.value;
obj.value=obj.value.replace(/^0(\d+)+/g,'$1').replace(/[^\d\.]/g,'');
}
}
</script>
#7
直接在你的输入框后面加上onKeyUp="value=value.replace(/[^1234567890]/g,'')" onbeforepaste="clipboardData.setData('text',clipboardData.getData('text').replace(/[^1234567890]/g,''))"
#1
但是用键盘左右键的时候,一直跳到文字的最后
完全不明白这句话的意思
完全不明白这句话的意思
#2
var _value = "";
function inp(obj){
if(_value==obj.value) return;
var regStrs = [
['^0(\\d+)', '$1'], //禁止录入整数部分两位以上,但首位为0
['[^0-9\]', ''] //禁止录入任何非数字和点
];
for(i=0; i<regStrs.length; i++){
var reg = new RegExp(regStrs[i][0],"g");
obj.value = obj.value.replace(reg, regStrs[i][1]);
}
_value = obj.value;
}
#3
要想光标一直在最后 可以先清空 在重新赋值就是在最后了
var obj=document.getElementById("testId");
var val=obj.value;
//obj.focus();
bj.value="";
obj.value=val;
var obj=document.getElementById("testId");
var val=obj.value;
//obj.focus();
bj.value="";
obj.value=val;
#4
当按左键键盘弹起的时候,又从新判断一下文本框中的值,它当然会跳到文字的最后,和你输入东西一样的效果
#5
#6
//原因是因为每按一下键盘都触发正则,并对输入框赋值,所以光标老是跑到最后。(FF不会)
//解决方法:判断输入框的值有没有变化才触发正则替换。
<input name="" type="text" value="" onKeyUp="inp(this)">
<script type="text/javascript">
var v="";
function inp(obj){
if(obj.value!=v){
v=obj.value;
obj.value=obj.value.replace(/^0(\d+)+/g,'$1').replace(/[^\d\.]/g,'');
}
}
</script>
#7
直接在你的输入框后面加上onKeyUp="value=value.replace(/[^1234567890]/g,'')" onbeforepaste="clipboardData.setData('text',clipboardData.getData('text').replace(/[^1234567890]/g,''))"