js基礎(chǔ):javascript設(shè)置文本框光標(biāo)
當(dāng)前位置:點(diǎn)晴教程→知識(shí)管理交流
→『 技術(shù)文檔交流 』
對(duì)于text //得到光標(biāo)位置 function getCaret(textbox) { var control = document.activeElement; textbox.focus(); var rang = document.selection.createRange(); rang.setEndPoint("StartToStart",textbox.createTextRange()) control.focus(); return rang.text.length; } 對(duì)于textarea function getCaret(ZysrID) { var txb = document.getElementById(ZysrID);//根據(jù)ID獲得對(duì)象 var pos = 0;//設(shè)置初始位置 txb.focus();//輸入框獲得焦點(diǎn),這句也不能少,不然后面會(huì)出錯(cuò),血的教訓(xùn)啦. var s = txb.scrollTop;//獲得滾動(dòng)條的位置 var r = document.selection.createRange();//創(chuàng)建文檔選擇對(duì)象 var t = txb.createTextRange();//創(chuàng)建輸入框文本對(duì)象 t.collapse(true);//將光標(biāo)移到頭 t.select();//顯示光標(biāo),這個(gè)不能少,不然的話(huà),光標(biāo)沒(méi)有移到頭.當(dāng)時(shí)我不知道,搞了十幾分鐘 var j = document.selection.createRange();//為新的光標(biāo)位置創(chuàng)建文檔選擇對(duì)象 r.setEndPoint("StartToStart",j);//在以前的文檔選擇對(duì)象和新的對(duì)象之間創(chuàng)建對(duì)象,媽的,不好解釋,我表達(dá)能力不算太好.有興趣自己去看msdn的資料 var str = r.text;//獲得對(duì)象的文本 var re = new RegExp("[\\n]","g");//過(guò)濾掉換行符,不然你的文字會(huì)有問(wèn)題,會(huì)比你的文字實(shí)際長(zhǎng)度要長(zhǎng)一些.搞死我了.我說(shuō)我得到的數(shù)字怎么總比我的實(shí)際長(zhǎng)度要長(zhǎng). str = str.replace(re,"");//過(guò)濾 pos = str.length;//獲得長(zhǎng)度.也就是光標(biāo)的位置 r.collapse(false); r.select();//把光標(biāo)恢復(fù)到以前的位置 txb.scrollTop = s;//把滾動(dòng)條恢復(fù)到以前的位置 } //設(shè)置光標(biāo)函數(shù) function setCaret(id,pos)
{ var textbox = document.all(id); var r = textbox.createTextRange(); r.collapse(true); r.moveStart(''character'',pos); r.select(); } 該文章在 2010/8/18 21:24:22 編輯過(guò) |
關(guān)鍵字查詢(xún)
相關(guān)文章
正在查詢(xún)... |