用javascript获取textarea中的光标位置


Posted in Javascript onMay 06, 2008

对于写javascript写网页编辑器的人来说,获取textarea中的光标位置是一个非常重要的问题,而往往很多人在这个地方不知所措,找不到好的办法。昨天我在网上找到了一段javascript代码,本来不想把原版放在这里的,就是因为太精彩了,怕我给改坏了,所以还是原版放在这里吧。

var start=0;
    var end=0;
    function add(){       
        var textBox = document.getElementById("ta");
        var pre = textBox.value.substr(0, start);
        var post = textBox.value.substr(end);
        textBox.value = pre + document.getElementById("inputtext").value + post;
    }
    function savePos(textBox){
        //如果是Firefox(1.5)的话,方法很简单
        if(typeof(textBox.selectionStart) == "number"){
            start = textBox.selectionStart;
            end = textBox.selectionEnd;
        }
        //下面是IE(6.0)的方法,麻烦得很,还要计算上'\n'
        else if(document.selection){
            var range = document.selection.createRange();
            if(range.parentElement().id == textBox.id){
                // create a selection of the whole textarea
                var range_all = document.body.createTextRange();
                range_all.moveToElementText(textBox);
                //两个range,一个是已经选择的text(range),一个是整个textarea(range_all)
                //range_all.compareEndPoints()比较两个端点,如果range_all比range更往左(further to the left),则                //返回小于0的值,则range_all往右移一点,直到两个range的start相同。
                // calculate selection start point by moving beginning of range_all to beginning of range
                for (start=0; range_all.compareEndPoints("StartToStart", range) < 0; start++)
                    range_all.moveStart('character', 1);
                // get number of line breaks from textarea start to selection start and add them to start
                // 计算一下\n
                for (var i = 0; i <= start; i ++){
                    if (textBox.value.charAt(i) == '\n')
                        start++;
                }
                // create a selection of the whole textarea
                 var range_all = document.body.createTextRange();
                 range_all.moveToElementText(textBox);
                 // calculate selection end point by moving beginning of range_all to end of range
                 for (end = 0; range_all.compareEndPoints('StartToEnd', range) < 0; end ++)
                     range_all.moveStart('character', 1);
                     // get number of line breaks from textarea start to selection end and add them to end
                     for (var i = 0; i <= end; i ++){
                         if (textBox.value.charAt(i) == '\n')
                             end ++;
                     }
                }
            }
        document.getElementById("start").value = start;
        document.getElementById("end").value = end;
    }
下面是在页面中调用js代码的方法:

<form action="a.cgi">
<table border="1" cellspacing="0" cellpadding="0">
    <tr>
        <td>start: <input type="text" id="start" size="3"/></td>
        <td>end: <input type="text" id="end" size="3"/></td>
    </tr>
    <tr>
        <td colspan="2">
            <textarea id="ta" onKeydown="savePos(this)"
                              onKeyup="savePos(this)"
                              onmousedown="savePos(this)"
                              onmouseup="savePos(this)"
                              onfocus="savePos(this)"
                              rows="14" cols="50"></textarea>
        </td>
    </tr>
    <tr>
        <td><input type="text" id="inputtext" /></td>
        <td><input type="button" onClick="add()" value="Add Text"/></td>
    </tr>
</table>
</form>
此代码的原文是:http://blog.csdn.net/liujin4049/archive/2006/09/19/1244065.aspx,在此谢过!

这段js代码同时支持IE和Firefox,甚是精彩,可见此人js功力深厚啊,呵呵。

Btw:听说Firefox现在的市场占有率已经达到17%了,而IE8也快出来了,浏览器之间又会掀起一场你死我活的争斗,而这种争斗可以使浏览器的解析标准会越来越规范,我们写代码也会越来越省事,这实在是一件值得高兴的事。

Javascript 相关文章推荐
动态表格Table类的实现
Aug 26 Javascript
javascript 24小时弹出一次的代码(利用cookies)
Sep 03 Javascript
JQuery 绑定事件时传递参数的实现方法
Oct 13 Javascript
document.getElementById方法在Firefox与IE中的区别
May 18 Javascript
JQuery live函数
Dec 24 Javascript
jQuery ui插件的使用方法代码实例
May 08 Javascript
jquery 删除字符串最后一个字符的方法解析
Feb 11 Javascript
easyui Droppable组件实现放置特效
Aug 19 Javascript
详解es6超好用的语法糖Decorator
Aug 01 Javascript
jQuery each和js forEach用法比较
Feb 27 jQuery
微信小程序wx.request拦截器使用详解
Jul 09 Javascript
微信小程序 如何保持登录状态
Aug 16 Javascript
用js实现下载远程文件并保存在本地的脚本
May 06 #Javascript
来自chinaz的ajax获取评论代码
May 03 #Javascript
定义select的边框颜色
Apr 28 #Javascript
JavaScript对象模型-执行模型
Apr 28 #Javascript
JavaScript面象对象设计
Apr 28 #Javascript
JS event使用方法详解
Apr 28 #Javascript
ext for eclipse插件安装方法
Apr 27 #Javascript
You might like
967 个函式
2006/10/09 PHP
PHP解压ZIP文件到指定文件夹的方法
2016/11/17 PHP
入门基础学习 ExtJS笔记(一)
2010/11/11 Javascript
javascript 基础篇2 数据类型,语句,函数
2012/03/14 Javascript
js数字转换为float,取N位小数
2014/02/08 Javascript
javascript的动态加载、缓存、更新以及复用(一)
2014/06/09 Javascript
JavaScript对象反射用法实例
2015/04/17 Javascript
bootstrap选项卡使用方法解析
2017/01/11 Javascript
angular.fromJson与toJson方法用法示例
2017/05/17 Javascript
jquery版轮播图效果和extend扩展
2017/07/18 jQuery
详解Chart.js轻量级图表库的使用经验
2018/05/22 Javascript
vue中子组件调用兄弟组件方法
2018/07/06 Javascript
Javascript删除数组里的某个元素
2019/02/28 Javascript
配置eslint规范项目代码风格
2019/03/11 Javascript
JS实现滚动条触底加载更多
2019/09/19 Javascript
nodejs实现聊天机器人功能
2019/09/19 NodeJs
优化Vue中date format的性能详解
2020/01/13 Javascript
使用wxPython获取系统剪贴板中的数据的教程
2015/05/06 Python
Python中matplotlib中文乱码解决办法
2017/05/12 Python
Python+OpenCV目标跟踪实现基本的运动检测
2018/07/10 Python
python将txt文件读取为字典的示例
2018/12/22 Python
使用Python操作FTP实现上传和下载的方法
2019/04/01 Python
python图片二值化提高识别率代码实例
2019/08/24 Python
python飞机大战 pygame游戏创建快速入门详解
2019/12/17 Python
解决Jupyter无法导入已安装的 module问题
2020/04/17 Python
浅谈Python 命令行参数argparse写入图片路径操作
2020/07/12 Python
HTML5 Canvas中使用路径描画二阶、三阶贝塞尔曲线
2015/01/01 HTML / CSS
浅谈Html5中视频 音频标签 进度条的问题
2016/07/26 HTML / CSS
中国最大的名表商城:万表网
2016/08/29 全球购物
英国汽车座椅和婴儿车购物网站:Uber Kids
2017/04/19 全球购物
瑞典快乐袜子:Happy Socks
2018/02/16 全球购物
Audible英国:有声读物,30天免费试用
2019/10/16 全球购物
戴尔马来西亚官网:Dell Malaysia
2020/05/02 全球购物
银行财务部实习生的自我鉴定
2013/11/27 职场文书
教育英语专业毕业生的求职信
2014/03/13 职场文书
互联网创业商业模式以及赚钱法则有哪些?
2019/10/12 职场文书