java文本框自由调整光标位置_javascript设置文本框光标的方法实例小结

本文实例总结了javascript设置文本框光标的方法。分享给大家供大家参考,具体如下:

对于text

//得到光标位置

function getCaret(textbox) {

var control = document.activeElement;

textbox.focus();

var rang = document.selection.createRange();

rang.setEndPoint("StartToStart",textbox.createTextRange())

control.focus();

return rang.text.length;

}

对于textarea

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();

}

希望本文所述对大家JavaScript程序设计有所帮助。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值