如何用Javascript获得TextArea中的光标位置

简介:

在添加代码的时候,只能添在TextArea的最后面,无法在光标之前插入,获得TextArea中的位置,但是如果TextArea中有很多内容的时候,会显得很闪烁。其代码如下。

function getPos(obj)
{
obj.focus();
var workRange=document.selection.createRange();
obj.select();
var allRange=document.selection.createRange();
workRange.setEndPoint("StartToStart",allRange);
var len=workRange.text.length;
workRange.collapse(false);
workRange.select();

return len;
}

这时候问题出来了,在obj.select()的时候,会造成闪烁,并且滚动条也无法归位。于是根据自己的需要,将其改写如下:

function getCaret(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;//获得长度.也就是光标的位置
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();
}



本文转自94cool博客园博客,原文链接:http://www.cnblogs.com/94cool/archive/2009/09/22/1571674.html,如需转载请自行联系原作者
 
相关文章
|
4月前
|
JavaScript API
js让光标选择节点中部分文本
js让光标选择节点中部分文本
35 1
|
8月前
|
JavaScript
【js中鼠标点击、移动和光标移动的事件触发】
【js中鼠标点击、移动和光标移动的事件触发】
165 0
|
移动开发 JavaScript 前端开发
javascript获取到textarea文本框中的回车换行符
作者:王先荣 结论     javascript获取到textarea文本框中的字符串中,如果包含有回车换行符,在字符串中表现为“\n”,而不是我们通常所见的“\r\n”。 发现问题     今天在做小网站的时候,需要将用户输入的英文分号、中英文逗号及回车都替换成中文分号,在编javascript函数的过程中,总是无法正确的替换回车。
1509 0
|
JavaScript 数据安全/隐私保护 Web App开发
|
JavaScript 前端开发
在页面中 js 获取光标/鼠标的坐标,获取光标的的像素坐标
近期为网站开发页面统计,以前虽然也开发过,但是功能不是很全,所以这次把一些好功能给用上。 例如这次的,页面JS光标/鼠标坐标,你也许问着有什么用,百度统计中有个热点统计图,这下清楚明白了吧。 好了,上肉: 功能:获取光标的的像素坐标 <html> <head> <script type="text/javascript"> fun
1674 0
|
JavaScript
js获取和设置文本框光标的位置
function getCursortPosition(ctrl) {//获取光标位置函数 var CaretPos = 0; // IE Support if (document.selection) { ctrl.
699 0
|
JavaScript 前端开发
javascript判断触发事件event的光标坐标,相对于客户区和屏幕
相对于客户区的坐标的使用:   function show_coords(event){x=event.clientXy=event.clientYalert("X 坐标: " + x + ", Y 坐标: " + y)} 请在文档中点击。
627 0