如何用Javascript获得TextArea中的光标位置
小弟最近在写一个在线编辑器,UBB版的,由于没有使用弹出窗口,所以,在添加代码的时候,只能添在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();
}
其实这个不难,但不知道的时候,会搞死人的。我为了实现这个效果,前前后后差不多试了五个小时,妈的。但愿这个对一些兄弟有帮助。
- · 怎么强制弹出窗口永远在最前面
- · 如何控制框架页的滚动
- · 在单元格里或层里出现滚动条
- · 实现页面打开后滚动到最底端的效果
- · Step By Step 制作XML的Javascript树形目录
- · 怎样屏蔽浏览器关闭按钮及ALT+F4 快捷键
- · 判断checkbox是否至少有选择一项
- · 全新的音乐防盗连技术
- · 解决未知尺寸的图片撑破页面的问题
- · 比较实用的首页调用文章的两个函数
- · 一个解析URL及图片地址的JS函数
- · 让处于contentEditable=true的层里面的图片响应键盘事件
- · 单击图片时直接出现另存为对话框
- · 单击图片时直接出现另存为对话框
- · JS控制INPUT格式时间输入
- · Javascript实现图片按比例缩放的函数
- · 网页中图片和文字相分离的方法
- · 用Javascript模仿DataGrid
- · JavaScript写自定义对象语法
- · 用javascript将数据导入Excel
- · Javascript所有对象的属性的获取
- · 有关清空表单的各种可能的操作
- · 鼠标放上去自动点击代码,只自动点一次
- · javascript设计模式交流(一) :Singleton Pattern
- · 用JavaScript检查文件大小
- · 在用户离开网页页面时提示信息
- · 弹出页中用javascript刷新父页
- · 参数传递解决window.open的session变量丢失
- · 完美解决一个事件激活多个函数
- · 脚本控制三行三列自适应高度DIV布局
- · 用Javascript强制设为首页的代码
- · Web上运行应用程序的一个方法
- · Web上运行应用程序的一个方法
- · 上传图片之前判断大小的解决办法(利用IE漏洞)
- · JavaScript实际应用:innerHTMl和确认提示的使用
- · 如何在IE右键菜单中添加菜单项
- · 客户端插入控件
- · 子父窗口之间的操作之小例子
