这里有新鲜出炉的 Javascript 教程,程序狗速度看过来!
Javascript 是一种由 Netscape 的 LiveScript 发展而来的原型化继承的基于对象的动态类型的区分大小写的客户端脚本语言,主要目的是为了解决服务器端语言,比如 Perl,遗留的速度问题,为客户提供更流畅的浏览效果。
这篇文章主要介绍了 javascript 设置文本框光标的方法, 结合实例形式总结分析了 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 程序设计有所帮助。
来源: http://www.phperz.com/article/17/0521/330649.html