由于需要對(duì)文本框內(nèi)容進(jìn)行校驗(yàn),將非法字符通過(guò)JS的replace函數(shù)過(guò)濾出去,但是這樣過(guò)濾對(duì)于在文本框內(nèi)容最后插入的非法字符沒(méi)有影響,如果在文本中間插入非法字符,那么將非法字符過(guò)濾掉之后,光標(biāo)就會(huì)跳到文本框的最后去,為了解決這個(gè)問(wèn)題,對(duì)replace進(jìn)行了增強(qiáng)處理.
<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;
}
/*
定位光標(biāo)
*/
function setCursorPos(obj,pos)
{
var rng =obj.createTextRange();
rng.moveStart(‘character‘,pos);
rng.collapse(true);
rng.select();
}
/*
替換后定位光標(biāo)在原處,可以這樣調(diào)用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);//保存原始光標(biāo)位置
var temp=obj.value; //保存原始值
obj.value=temp.replace(pattern,text);//替換掉非法值
pos=pos-(temp.length-obj.value.length);//當(dāng)前光標(biāo)位置
setCursorPos(obj,pos);//設(shè)置光標(biāo)
}
//這里是對(duì)增強(qiáng)后的函數(shù)的調(diào)用,這里只能輸入數(shù)字,如果輸入其他字符將被過(guò)濾掉
/
function inputNumberOnly(text){
replaceAndSetPos(text,/[^\d]/g,‘‘);
}
</script>
在html頁(yè)面中調(diào)用如下:
<input type="text" name="nsrsbh" maxlength="20" size="30" tabindex="1" onkeyup="inputNumberOnly(this)">
這樣該文本框就只能輸入數(shù)字,對(duì)于其他字符進(jìn)行過(guò)濾.并保持光標(biāo)的位置