国产一级a片免费看高清,亚洲熟女中文字幕在线视频,黄三级高清在线播放,免费黄色视频在线看

打開APP
userphoto
未登錄

開通VIP,暢享免費電子書等14項超值服

開通VIP
html 文本框屏蔽非法字符
html 文本框屏蔽非法字符,解決js的replace函數(shù)使光標跳到文本最后的問題

  由于需要對文本框內(nèi)容進行校驗,將非法字符通過JS的replace函數(shù)過濾出去,但是這樣過濾對于在文本框內(nèi)容最后插入的非法字符沒有影響,如果在文本中間插入非法字符,那么將非法字符過濾掉之后,光標就會跳到文本框的最后去,為了解決這個問題,對replace進行了增強處理.

<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();
}

/*
替換后定位光標在原處,可以這樣調(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);//保存原始光標位置
 var temp=obj.value; //保存原始值
 obj.value=temp.replace(pattern,text);//替換掉非法值
 pos=pos-(temp.length-obj.value.length);//當前光標位置
 
 setCursorPos(obj,pos);//設(shè)置光標
}

//這里是對增強后的函數(shù)的調(diào)用,這里只能輸入數(shù)字,如果輸入其他字符將被過濾掉

/
        function inputNumberOnly(text){
  replaceAndSetPos(text,/[^\d]/g,‘‘);
  }
  
</script>

在html頁面中調(diào)用如下:

<input type="text" name="nsrsbh" maxlength="20" size="30" tabindex="1"  onkeyup="inputNumberOnly(this)">

這樣該文本框就只能輸入數(shù)字,對于其他字符進行過濾.并保持光標的位置

本站僅提供存儲服務,所有內(nèi)容均由用戶發(fā)布,如發(fā)現(xiàn)有害或侵權(quán)內(nèi)容,請點擊舉報。
打開APP,閱讀全文并永久保存 查看更多類似文章
猜你喜歡
類似文章
獲得光標在各種文本框中的位置
javascript 光標定位
如何把文本框的焦點定在文本框的文字之后
常用作帖、發(fā)帖代碼集萃
Excel表格的單元格中如何插入一條斜線,在左右輸入漢字
特殊字符過濾,js
更多類似文章 >>
生活服務
分享 收藏 導長圖 關(guān)注 下載文章
綁定賬號成功
后續(xù)可登錄賬號暢享VIP特權(quán)!
如果VIP功能使用有故障,
可點擊這里聯(lián)系客服!

聯(lián)系客服