javascript设置文本框光标的方法实例小结
本文实例总结了javascript设置文本框光标的方法。分享给大家供大家参考,具体如下:
对于text
//得到光标位置
functiongetCaret(textbox){
varcontrol=document.activeElement;
textbox.focus();
varrang=document.selection.createRange();
rang.setEndPoint("StartToStart",textbox.createTextRange())
control.focus();
returnrang.text.length;
}
对于textarea
functiongetCaret(ZysrID)
{
vartxb=document.getElementById(ZysrID);//根据ID获得对象
varpos=0;//设置初始位置
txb.focus();//输入框获得焦点,这句也不能少,不然后面会出错,血的教训啦.
vars=txb.scrollTop;//获得滚动条的位置
varr=document.selection.createRange();//创建文档选择对象
vart=txb.createTextRange();//创建输入框文本对象
t.collapse(true);//将光标移到头
t.select();//显示光标,这个不能少,不然的话,光标没有移到头.当时我不知道,搞了十几分钟
varj=document.selection.createRange();//为新的光标位置创建文档选择对象
r.setEndPoint("StartToStart",j);//在以前的文档选择对象和新的对象之间创建对象,妈的,不好解释,我表达能力不算太好.有兴趣自己去看msdn的资料
varstr=r.text;//获得对象的文本
varre=newRegExp("[//n]","g");//过滤掉换行符,不然你的文字会有问题,会比你的文字实际长度要长一些.搞死我了.我说我得到的数字怎么总比我的实际长度要长.
str=str.replace(re,"");//过滤
pos=str.length;//获得长度.也就是光标的位置
r.collapse(false);
r.select();//把光标恢复到以前的位置
txb.scrollTop=s;//把滚动条恢复到以前的位置
}
设置光标函数
functionsetCaret(id,pos)
{
vartextbox=document.all(id);
varr=textbox.createTextRange();
r.collapse(true);
r.moveStart('character',pos);
r.select();
}
更多关于JavaScript相关内容感兴趣的读者可查看本站专题:《JavaScript查找算法技巧总结》、《JavaScript数据结构与算法技巧总结》、《JavaScript遍历算法与技巧总结》、《JavaScript中json操作技巧总结》、《JavaScript切换特效与技巧总结》、《JavaScript动画特效与技巧汇总》、《JavaScript错误与调试技巧总结》及《JavaScript数学运算用法总结》
希望本文所述对大家JavaScript程序设计有所帮助。