<HTML> <HEAD> <TITLE>测试网页</TITLE> <SCRIPT> //获取光标所在文本框的位置 function getCaret(textbox) { var control = document.activeElement; textbox.focus(); var rang = document.selection.createRange(); rang.setEndPoint("StartToStart",textbox.createTextRange()) control.focus(); alert(rang.text.length); } //获取光标所在文本域的位置 function getCaretForTextArea(ZysrID){ var txb = document.getElementById(ZysrID);//根据ID获得对象 var pos = 0;//设置初始位置 txb.focus();//输入框获得焦点,这句也不能少,不然后面会出错,血的教训啦. var s = txb.scrollTop;//获得滚动条的位置 var r = document.selection.createRange();//创建文档选择对象 var t = txb.createTextRange();//创建输入框文本对象 t.collapse(true);//将光标移到头 t.select();//显示光标,这个不能少,不然的话,光标没有移到头.当时我不知道,搞了十几分钟 var j = document.selection.createRange();//为新的光标位置创建文档选择对象 r.setEndPoint("StartToStart",j);//在以前的文档选择对象和新的对象之间创建对象,妈的,不好解释,我表达能力不算太好.有兴趣自己去看msdn的资料 var str = r.text;//获得对象的文本 var re = new RegExp("[//n]","g");//过滤掉换行符,不然你的文字会有问题,会比你的文字实际长度要长一些.搞死我了.我说我得到的数字怎么总比我的实际长度要长. str = str.replace(re,"");//过滤 pos = str.length;//获得长度.也就是光标的位置 alert(pos); r.collapse(false); r.select();//把光标恢复到以前的位置 txb.scrollTop = s;//把滚动条恢复到以前的位置 } //设置光标在文本框中的位置 function setCaret(id,pos){ var textbox = document.all(id); var r = textbox.createTextRange(); r.collapse(true); r.moveStart('character',pos); r.select(); } //设置光标位置的调用函数 function readyforset(id){ var pos = document.getElementById('setpos').value; setCaret(id,pos); } </SCRIPT> </HEAD> <BODY> 在此输入框中输入内容,以测试相关的功能:<br/> <input id=eim type=text value='' style="width: 300px;background-color: orange;" /><br/><br/> 功能按钮区:<br/> <input type=button value="获取光标位置" οnclick="getCaret(document.getElementById('eim'))" /><br/><br/> <input type=button value="设置光标位置" οnclick="readyforset('eim')" /><input type=text id=setpos value='0' /> <br/><br/><br/><br/><br/> <textarea id="eimarea" col="5" row="5"></textarea><br/> <input type=button value="获取文本域光标位置" οnclick="getCaretForTextArea('eimarea')" /> </BODY> </HTML>