用户操作
[即时聊天] [发私信] [加为好友]
爱你网ID:goody9807
149913次访问,排名553,好友243人,关注者0人。
http://www.cnblogs.com/goody9807
http://www.51ini.com
goody9807的文章
原创 93 篇
翻译 0 篇
转载 139 篇
评论 90 篇
爱你网的公告








一个不错的P2P软件,里面肯定有你要的资源

我的爱你网,讨论.Net


最近评论
Kaelzhang:您好,今天无意路过这里,发现阁下转载了本站的日志。可能你是从其他的地方转载的,也有可能是从本站转载的。

但是不论是哪一种情况,请加上本站原文的有效链接,http://yottaworks.net/general/142/
或者
http://www.kael.com.cn

感谢您的支持,遵守Creative Commons,互相……
xiaojiit:能不能支态变宽呢?
z392989029:美女,你也学编程吗。
这个东西我还是不会用
z392989029:美女,你也学编程吗。
这个东西我还是不会用
hhshang:楼主你做过这个打字程序,如果做了,可不可以发一份给我学习一下呀,我的邮箱是:zeng_xianchun@126.com
文章分类
收藏
相册
Csdn专用
个人专用
XML相关资料
XML Server与XML-enabled Web Server介绍
xmlhttp发送 xml 例子详解
在Asp.net里显示XML格式内容.
树的资料
asp.net中的treeview 怎么用
数据库连接
CSDN数据库连接大全
DSN方式连接数据库
杂类
100分问一个突然出现的Cookie问题,关于添加/删除Cookie的。
c#存取图片 (RSS)
我的主页(RSS)
高效.TEXTBLOG技巧终结篇
存档
软件项目交易
订阅我的博客
XML聚合  FeedSky
订阅到鲜果
订阅到Google
订阅到抓虾
订阅到BlogLines
订阅到Yahoo
订阅到GouGou
订阅到飞鸽
订阅到Rojo
订阅到newsgator
订阅到netvibes

转载 [zt]如何用Javascript获得TextArea中的光标位置 收藏

新一篇: Windows Live Writer新版新功能试用  | 旧一篇: 建立自动备份的维护计划

小弟最近在写一个在线编辑器,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(); }

  其实这个不难,但不知道的时候,会搞死人的。我为了实现这个效果,前前后后差不多试了五个小时,妈的。但愿这个对一些兄弟有帮助。

发表于 @ 2008年06月23日 11:05:30|评论(loading...)|编辑|收藏

新一篇: Windows Live Writer新版新功能试用  | 旧一篇: 建立自动备份的维护计划

评论

#yw2008wy 发表于2008-09-05 18:08:14  IP: 211.101.131.*
写得不错,我还没有试试,不过挺感谢帖出来
发表评论  


当前用户设置只有注册用户才能发表评论。如果你没有登录,请点击登录
Csdn Blog version 3.1a
Copyright © 爱你网