由于需要對文本框內容進(jìn)行校驗,將非法字符通過(guò)JS的replace函數過(guò)濾出去,但是這樣過(guò)濾對于在文本框內容最后插入的非法字符沒(méi)有影響,如果在文本中間插入非法字符,那么將非法字符過(guò)濾掉之后,光標就會(huì )跳到文本框的最后去,為了解決這個(gè)問(wèn)題,對replace進(jìn)行了增強處理.
<script type="text/javascript">
function getCursorPos(obj)
{
obj.focus();
var currentRange=document.selection.createRange();
var workRange=currentRange.duplicate();
obj.select();
var allRange=document.selection.createRange();
var pos=0;
while(workRange.compareEndPoints("StartToStart",allRange)>0)
{
workRange.moveStart("character",-1);
pos++;
}
currentRange.select();
return pos;
}
/*
定位光標
*/
function setCursorPos(obj,pos)
{
var rng =obj.createTextRange();
rng.moveStart(‘character‘,pos);
rng.collapse(true);
rng.select();
}
/*
替換后定位光標在原處,可以這樣調用onkeyup=replaceAndSetPos(this,/[^\d]/g,‘‘);
*/
function replaceAndSetPos(obj,pattern,text){
if(event.shiftKey||event.altKey||event.ctrlKey||event.keyCode==16||event.keyCode==17||event.keyCode==18||(event.shiftKey&&event.keyCode==36))
return;
var pos=getCursorPos(obj);//保存原始光標位置
var temp=obj.value; //保存原始值
obj.value=temp.replace(pattern,text);//替換掉非法值
pos=pos-(temp.length-obj.value.length);//當前光標位置
setCursorPos(obj,pos);//設置光標
}
//這里是對增強后的函數的調用,這里只能輸入數字,如果輸入其他字符將被過(guò)濾掉
/
function inputNumberOnly(text){
replaceAndSetPos(text,/[^\d]/g,‘‘);
}
</script>
在html頁(yè)面中調用如下:
<input type="text" name="nsrsbh" maxlength="20" size="30" tabindex="1" onkeyup="inputNumberOnly(this)">
這樣該文本框就只能輸入數字,對于其他字符進(jìn)行過(guò)濾.并保持光標的位置
聯(lián)系客服