技術(shù)分享 Javascript如何獲取textarea中光標(biāo)位置
這里和大家分享一下如何用Javascript獲取textarea中的光標(biāo)位置,相信本文介紹一定會(huì)讓你有所收獲的。
用Javascript獲取textarea中的光標(biāo)位置
Javascript一向以他的靈活隨意而著稱,這也使得它的功能可以非常的強(qiáng)大,而由于沒有比較好的調(diào)試工具,又使得它使用起來困難重重,尤其使對(duì)于一些初學(xué)者,更是感覺到無從下手。今天探討的問題是用javascript獲取textarea中光標(biāo)的位置。對(duì)于寫javascript寫網(wǎng)頁編輯器的人來說,獲取textarea中的光標(biāo)位置是一個(gè)非常重要的問題,而往往很多人在這個(gè)地方不知所措,找不到好的辦法。昨天我在網(wǎng)上找到了一段javascript代碼,本來不想把原版放在這里的,就是因?yàn)樘柿?,怕我給改壞了,所以還是原版放在這里吧。
- varstart=0;
- varend=0;
- functionadd(){
- vartextBox=document.getElementById("ta");
- varpre=textBox.value.substr(0,start);
- varpost=textBox.value.substr(end);
- textBox.value=pre+document.
- getElementById("inputtext").value+post;
- }
- functionsavePos(textBox){
- //如果是Firefox(1.5)的話,方法很簡(jiǎn)單
- if(typeof(textBox.selectionStart)=="number"){
- start=textBox.selectionStart;
- end=textBox.selectionEnd;
- }
- //下面是IE(6.0)的方法,麻煩得很,還要計(jì)算上'\n'
- elseif(document.selection){
- varrange=document.selection.createRange();
- if(range.parentElement().id==textBox.id){
- //createaselectionofthewholetextarea
- varrange_all=document.body.createTextRange();
- range_all.moveToElementText(textBox);
- //兩個(gè)range,一個(gè)是已經(jīng)選擇的text(range),
- 一個(gè)是整個(gè)textarea(range_all)
- //range_all.compareEndPoints()比較兩個(gè)端點(diǎn),
- 如果range_all比range更往左(furthertotheleft),
- 則//返回小于0的值,則range_all往右移一點(diǎn),直到兩個(gè)range的start相同。
- //calculateselectionstartpointbymoving
- beginningofrange_alltobeginningofrange
- for(start=0;range_all.compareEndPoints
- ("StartToStart",range)<0;start++)range_all.moveStart('character',1);
- //getnumberoflinebreaksfromtextareastarttose
- lectionstartandaddthemtostart
- //計(jì)算一下\n
- for(vari=0;i<=start;i++){
- if(textBox.value.charAt(i)=='\n')
- start++;
- }
- //createaselectionofthewholetextarea
- varrange_all=document.body.createTextRange();
- range_all.moveToElementText(textBox);
- //calculateselectionendpointbymovingbeginningofrange_alltoendofrange
- for(end=0;range_all.compareEndPoints('StartToEnd',range)<0;end++)
- range_all.moveStart('character',1);
- //getnumberoflinebreaksfromtextareastarttoselectionendandaddthemtoend
- for(vari=0;i<=end;i++){
- if(textBox.value.charAt(i)=='\n')
- end++;
- }
- }
- }
- document.getElementById("start").value=start;
- document.getElementById("end").value=end;
- }
下面是在頁面中調(diào)用js代碼的方法:
- <formactionformaction="a.cgi">
- <tablebordertableborder="1"
- cellspacing="0"cellpadding="0">
- <tr>
- <td>start:<inputtypeinputtype="text"
- id="start"size="3"/></td>
- <td>end:<inputtypeinputtype="text"
- id="end"size="3"/></td>
- </tr>
- <tr>
- <tdcolspantdcolspan="2">
- <textareaidtextareaid="ta"onKeydown="savePos(this)"
- onKeyup="savePos(this)"
- onmousedown="savePos(this)"
- onmouseup="savePos(this)"
- onfocus="savePos(this)"
- rows="14"cols="50"></textarea>
- </td>
- </tr>
- <tr>
- <td><inputtypeinputtype="text"
- id="inputtext"/></td>
- <td><inputtypeinputtype="button"
- onClick="add()"value="AddText"/></td>
- </tr>
- </table>
- </form>
【編輯推薦】
- Javascript解決瀏覽器兼容問題12個(gè)技巧
- JS中Array數(shù)組的三大屬性用法揭秘
- 解析Javascript對(duì)select下拉列表操作
- 技術(shù)分享 如何識(shí)別控制DHTML和JS中的頁面元素
- 深入學(xué)習(xí)JavaScript中Function對(duì)象語法