用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 相关文章推荐
jquery $.ajax入门应用一
Nov 19 Javascript
Jquery命名冲突解决的五种方案分享
Mar 16 Javascript
你的 mixin 真的兼容 ECMAScript 5 吗?
Apr 11 Javascript
动态标签 悬停效果 延迟加载示例代码
Nov 21 Javascript
判断日期是否能跨月查询的js代码
Jul 25 Javascript
JavaScript闭包和范围实例详解
Dec 19 Javascript
基于vue2.0实现简单轮播图
Nov 27 Javascript
Vue CLI3 如何支持less的方法示例
Aug 29 Javascript
three.js实现炫酷的全景3D重力感应
Dec 30 Javascript
关于Vue源码vm.$watch()内部原理详解
Apr 26 Javascript
Layui实现主窗口和Iframe层参数传递
Nov 14 Javascript
从Node.js事件触发器到Vue自定义事件的深入讲解
Jun 26 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
非常好的php目录导航文件代码
2006/10/09 PHP
php在字符串中查找另一个字符串
2008/11/19 PHP
PHP 向右侧拉菜单实现代码,测试使用中
2009/11/03 PHP
MySQL时间字段究竟使用INT还是DateTime的说明
2012/02/27 PHP
PHP原生模板引擎 最简单的模板引擎
2012/04/25 PHP
解析php DOMElement 操作xml 文档的实现代码
2013/05/10 PHP
ThinkPHP空模块和空操作详解
2014/06/30 PHP
Laravel 5 框架入门(二)构建 Pages 的管理功能
2015/04/09 PHP
PHP常用函数之获取汉字首字母功能示例
2019/10/21 PHP
基于JavaScript代码实现兼容各浏览器的设为首页和加入收藏
2016/01/07 Javascript
jQuery Ajax 实例代码 ($.ajax、$.post、$.get)
2016/04/29 Javascript
每日十条JavaScript经验技巧(一)
2016/06/23 Javascript
js利用正则表达式检验输入内容是否为网址
2016/07/05 Javascript
Vue+webpack项目基础配置教程
2018/02/12 Javascript
vue中添加mp3音频文件的方法
2018/03/02 Javascript
webpack+vue-cli项目中引入外部非模块格式js的方法
2018/09/28 Javascript
bootstrap table列和表头对不齐的解决方法
2019/07/19 Javascript
在Layui 的表格模板中,实现layer父页面和子页面传值交互的方法
2019/09/10 Javascript
Vue实现验证码功能
2019/12/03 Javascript
python使用wmi模块获取windows下的系统信息 监控系统
2015/10/27 Python
详解 Python 读写XML文件的实例
2017/08/02 Python
python用户管理系统
2018/03/13 Python
Django获取该数据的上一条和下一条方法
2019/08/12 Python
使用python绘制二维图形示例
2019/11/22 Python
canvas烟花特效锦集
2018/01/17 HTML / CSS
Square Off美国/加拿大:世界上最聪明的国际象棋棋盘
2018/12/06 全球购物
日本高岛屋百货购物网站:TAKASHIMAYA
2019/03/24 全球购物
C语言面试题
2013/05/19 面试题
司机职责范本
2014/03/08 职场文书
天下第一关导游词
2015/02/06 职场文书
安全教育主题班会教案
2015/08/12 职场文书
班主任工作经验交流会总结
2015/11/02 职场文书
带你彻底理解JavaScript中的原型对象
2021/04/14 Javascript
MySQL中一条SQL查询语句是如何执行的
2022/04/08 MySQL
nginx.conf配置文件结构小结
2022/04/08 Servers
基于Python实现nc批量转tif格式
2022/08/14 Python