TextRange的傳統用途是對用戶在Web " /> 九九热精品视频在线,国产精品毛片一区二区三区,日韩www

中文字幕日韩一区二区_国产一区二区av_国产毛片av_久久久久国产一区_色婷婷电影_国产一区二区精品

使用TextRange獲取輸入框中光標的位置的代碼

TextRange是用來表現HTML元素中文字的對象,雖然我們平時不太常用這個對象,可是它卻在IE4.0中就已提供了。不過TextRange提供的調用方法卻都比較晦澀,那么我們能拿它做些什么呢? 

    TextRange的傳統用途是對用戶在Web頁上用鼠標圈選的文字內容的操作,比如變化、刪除、新增等。但其經典的用途卻是,在Web頁面中查找文字(這個比較簡單)和獲取輸入框光標的位置。其中后者又有可以衍生出很多更有用的用途,比如:限制輸入的MaskTextBox,其核心技術點就是獲取輸入框的光標位置,然后使用正則表達式判斷輸入內容。還有我后面會介紹的"使用方向鍵在輸入框矩陣中自然的導航",核心技術點也是獲取輸入框中的光標位置。 

    獲取輸入框中的光標位置的整個代碼其實很短,只是這些對象和方法不太常用而已。 
<script language="Javascript"> 
function GetCursorPsn(txb) 

    var slct = document.selection; 
    var rng = slct.createRange(); 
    txb.select(); 
    rng.setEndPoint("StartToStart", slct.createRange()); 
    var psn = rng.text.length; 
    rng.collapse(false); 
    rng.select(); 
    return psn; 

</script> 

    要徹底的弄清楚TextRange的具體用法,需要了解與其相關的一些內容,請參考MSDN。 



    這里說一下使用這個GetCursorPsn()方法后,會給輸入框操作帶來的副作用。對于輸入框<input type="text" onkeydown="GetCursorPsn(this)">,它將不能再使用Shift+左右這兩個方向鍵來選擇文本;對于<textarea onkeydown="GetCursorPsn(this)"></textarea>,將不能再使用Shift+上下左右四個方向鍵來選擇文本。因為代碼在獲取了當前光標到文本的startPoint后,調用rng.collapse(false);會改變文本筐內文本的EditPoint。不過這個副作用基本不會給我們使用文本框帶來什么大的問題,所以基本不用太在意。

JavaScript技術使用TextRange獲取輸入框中光標的位置的代碼,轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: 在线视频 亚洲 | 国产ts人妖另类 | 亚洲一二三区在线观看 | 日韩看片 | 天堂亚洲网 | av在线一区二区 | 欧美久久一区二区 | www.蜜桃av | 九色91视频 | 日韩在线国产 | 亚洲天堂中文字幕 | 99精品免费在线观看 | 国产精品一区二区三区在线 | 国产一极毛片 | 欧美激情欧美激情在线五月 | 一区二区精品 | 午夜一级黄色片 | 黄色网址在线免费观看 | 国产精品国产三级国产aⅴ原创 | 欧美v在线 | www.色综合 | 91精品国产综合久久福利软件 | 亚洲一区二区免费 | 一级黄在线观看 | 新91视频网| 日本黄色片免费在线观看 | 无码日韩精品一区二区免费 | 午夜天堂精品久久久久 | 国产一级免费视频 | 亚洲精品久久久蜜桃 | 成人在线观看免费 | 欧洲精品在线观看 | 天色综合网| 国产激情网站 | 亚洲午夜av久久乱码 | eeuss国产一区二区三区四区 | 亚洲精品在线免费观看视频 | 国产一区二区在线91 | 国产高清亚洲 | 一级全黄视频 | 天堂av中文在线 |