用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 相关文章推荐
Vue.js双向绑定操作技巧(初级入门)
Dec 27 Javascript
让div运动起来 js实现缓动效果
Jul 06 Javascript
浅谈angular4生命周期钩子
Sep 05 Javascript
jQuery访问浏览器本地存储cookie、localStorage和sessionStorage的基本用法
Oct 20 jQuery
javascript实现QQ空间相册展示源码
Dec 12 Javascript
JavaScript原生实现观察者模式的示例
Dec 15 Javascript
学习Vue组件实例
Apr 28 Javascript
详解vue更改头像功能实现
Apr 28 Javascript
微信小程序收货地址API兼容低版本解决方法
May 18 Javascript
jQuery实现input输入框获取焦点与失去焦点时提示的消失与显示功能示例
May 27 jQuery
浅谈vuex中store的命名空间
Nov 08 Javascript
jQuery是用来干什么的 jquery其实就是一个js框架
Feb 04 jQuery
用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
PHP7安装Redis扩展教程【Linux与Windows平台】
2016/09/30 PHP
thinkPHP5.1框架路由::get、post请求简单用法示例
2019/05/06 PHP
根据经纬度计算地球上两点之间的距离js实现代码
2013/03/05 Javascript
JQuery事件e参数的方法preventDefault()取消默认行为
2013/09/26 Javascript
js给页面加style无效果的解决方法
2014/01/20 Javascript
javascript白色简洁计算器
2015/05/04 Javascript
nodeJs爬虫获取数据简单实现代码
2016/03/29 NodeJs
基于bootstrap写的一点localStorage本地储存
2017/11/21 Javascript
记一次webapck4 配置文件无效的解决历程
2018/09/19 Javascript
微信小程序实现的绘制table表格功能示例
2019/04/26 Javascript
[52:44]VGJ.T vs infamous Supermajor小组赛D组败者组第一轮 BO3 第一场 6.3
2018/06/04 DOTA
在Python的Django框架中包装视图函数
2015/07/20 Python
Python脚本实现自动将数据库备份到 Dropbox
2017/02/06 Python
Python实现的弹球小游戏示例
2017/08/01 Python
基于python中的TCP及UDP(详解)
2017/11/06 Python
微信跳一跳python代码实现
2018/01/05 Python
浅谈python下tiff图像的读取和保存方法
2018/12/04 Python
python实现感知器算法(批处理)
2019/01/18 Python
Pandas分组与排序的实现
2019/07/23 Python
在python中计算ssim的方法(与Matlab结果一致)
2019/12/19 Python
Python json解析库jsonpath原理及使用示例
2020/11/25 Python
德国高品质男装及配饰商城:Cultizm(Raw Denim原色牛仔裤)
2018/04/16 全球购物
EQVVS官网:设计师男装和女装
2018/10/24 全球购物
英国最受欢迎的在线隐形眼镜商店:VisionDirect.co.uk
2018/12/06 全球购物
如何强制垃圾回收
2015/10/06 面试题
工商管理本科毕业生求职信范文
2013/10/05 职场文书
安全检查与奖惩制度
2014/01/23 职场文书
集团公司党的群众路线教育实践活动工作总结
2014/03/03 职场文书
市政工程技术专业自荐书
2014/07/06 职场文书
妇联领导班子剖析材料
2014/08/21 职场文书
2014医学院领导干部四风对照检查材料思想汇报
2014/09/16 职场文书
2014年村官工作总结
2014/11/24 职场文书
公司市场部岗位职责
2015/04/15 职场文书
单位病假条范文
2015/08/17 职场文书
导游词之五台山
2019/10/11 职场文书
Python 流媒体播放器的实现(基于VLC)
2021/04/28 Python