可能许多朋友会对新浪微博和沪江碎碎里,敲入@时弹出用户列表的功能是如何实现的比较困惑。

其中,最难解决的问题应该就是获取当前光标据文本框的相对位置了。因为一个普通的<textarea></textarea>通过正常的途径是无法获取到的。

那怎么办呢~

第一步:创建一个普通的TextArea框,然后在TextArea外层套一个DIV(DIV的Position设为relative,到时候会根据这个div来定位弹出框的位置)

第二步:创建一个与TextArea 同样尺寸的DIV(这个DIV在什么位置无所谓)在此我先称其为div_textarea。

注意:该DIV的所使用的字体,文字的大小,行间距等都要与文本框里所使用的一致。然后将 div_textarea 的Position也设为relative,visibility设为hidden(这个是背后操作的,当然不能让人看到啦)

说明:该DIV的作用就是用来获取输入@时光标的相对位置的。

结构如下:

第三步:脚本获取相对位置

操作: 当用户输入@了,通过脚本自动将文本框里的这些字符复制到 div_textarea 里,然后获取当前文本框光标在第几个字的后面,获得后在@相当于文本框的同样位置,插入<span class="nowpos"></span>(该span和@的相对位置应该是一样的)。

插入完后,那只要获得这个span离 div_textarea 的相对位置,就知道@离文本框的位置了。

获得相对位置了

看个js实现代码

所以还是原版放在这里吧。

varstart=0;  varend=0;  functionadd(){  vartextBox=document.getElementById("ta");  varpre=textBox.value.substr(0,start);  varpost=textBox.value.substr(end);  textBox.value=pre+document.getElementById("inputtext").value+post;  }  functionsavePos(textBox){  //如果是Firefox(1.5)的话,方法很简单  if(typeof(textBox.selectionStart)=="number"){  start=textBox.selectionStart;  end=textBox.selectionEnd;  }  //下面是IE(6.0)的方法,麻烦得很,还要计算上'n'  elseif(document.selection){  varrange=document.selection.createRange();  if(range.parentElement().id==textBox.id){  //createaselectionofthewholetextarea  varrange_all=document.body.createTextRange();  range_all.moveToElementText(textBox);  //两个range,一个是已经选择的text(range),  一个是整个textarea(range_all)  //range_all.compareEndPoints()比较两个端点,  如果range_all比range更往左(furthertotheleft),  则//返回小于0的值,则range_all往右移一点,直到两个range的start相同。  //calculateselectionstartpointbymovingbeginningofrange_alltobeginningofrange  for(start=0;range_all.compareEndPoints("StartToStart",range)<0;start++)range_all.moveStart('character',1);  //getnumberoflinebreaksfromtextareastarttoselectionstartandaddthemtostart  //计算一下n  for(vari=0;i<=start;i++){  if(textBox.value.charAt(i)=='n')  start++;  }  //createaselectionofthewholetextarea  varrange_all=document.body.createTextRange();  range_all.moveToElementText(textBox);  //calculateselectionendpointbymovingbeginningofrange_alltoendofrange  for(end=0;range_all.compareEndPoints('StartToEnd',range)<0;end++)  range_all.moveStart('character',1);  //getnumberoflinebreaksfromtextareastarttoselectionendandaddthemtoend  for(vari=0;i<=end;i++){  if(textBox.value.charAt(i)=='n')  end++;  }  }  }  document.getElementById("start").value=start;  document.getElementById("end").value=end;  }  下面是在页面中调用js代码的方法:<formactionformaction="a.cgi"> <tablebordertableborder="1"cellspacing="0"cellpadding="0"> <tr> <td>start:<inputtypeinputtype="text"id="start"size="3"/></td> <td>end:<inputtypeinputtype="text"id="end"size="3"/></td> </tr> <tr> <tdcolspantdcolspan="2"> <textareaidtextareaid="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><inputtypeinputtype="text"id="inputtext"/></td> <td><inputtypeinputtype="button"onClick="add()"value="AddText"/></td> </tr> </table> </form>

转自:http://www.111cn.net/wy/js-ajax/38581.htm

转载于:https://www.cnblogs.com/liuensong/archive/2012/11/30/10140388.html

js TextArea获取光标详解说明与实例相关推荐

  1. SpringSecurity的安全认证的详解说明(附完整代码)

    SpringSecurity登录认证和请求过滤器以及安全配置详解说明 环境 系统环境:win10 Maven环境:apache-maven-3.8.6 JDK版本:1.8 SpringBoot版本:2 ...

  2. react/antd实现textarea获取光标位置在光标处插入文字

    react/antd实现textarea获取光标位置在光标处插入文字 1.首先将textarea对象通过refs存起来 <TextArearef={(input) => this.cont ...

  3. 深度学习卷积神经网络CNN之 VGGNet模型主vgg16和vgg19网络模型详解说明(理论篇)

    1.VGG背景 2. VGGNet模型结构 3. 特点(创新.优缺点及新知识点) 一.VGG背景    VGGNet是2014年ILSVRC(ImageNet Large Scale Visual R ...

  4. JavaScript 中获取光标位置

    1.概念和原理 DOM中并没有直接获取光标位置的方法,那么我们只能间接来获取光标位置.DOM支持获取光标选中的范围,我们可以以此为切入点,来获取或定位光标的位置,当选取范围起始点和结束点一样时,就是光 ...

  5. contentEditable,window.getSelection详解---可编辑div,容器,设置/获取光标位置,光标处插入内容及光标的操作

    这周碰到一个东西,contentEditable ,它是用来指定一个元素是否是可编辑的,这也是富文本编辑器实现的底层支持,网上关于这部分东西的资料比较少或者不全,所以我来整理下关于这个属性,和可编辑区 ...

  6. js获取光标,设置光标位置

    直接贴代码,作为日常开发笔记 /* 设置光标位置* @params {Object} ele 输入框元素* @params {Number} pos 需要将光标设置的位置* @author *** 2 ...

  7. php获取laydate,详解关于laydate.js加载laydate.css路径错误问题

    laydate.js是属于Javascript系列的一款日期控件与时间插件,laydate.js支持兼容IE6在内的主流浏览器.laydate.js经过贤心大大的重写之后功能越来越强大,用起来也愈渐灵 ...

  8. php调用win32 api,C#_c#使用win32api实现获取光标位置,方法一:需要调用win32api,winfo - phpStudy...

    c#使用win32api实现获取光标位置 方法一:需要调用win32api,winform.wpf通用 [DllImport("user32.dll")] public stati ...

  9. js textarea焦点事件,CodeMirror焦点事件

    1,效果图 2,功能说明 当我把光标放在[指标对象]的控件框的时候,双击[字段名称],则字段数据写入指标对象控件框 当我把光标放在[指标维度]的控件框的时候,双击[字段名称],则字段数据写入指标维度控 ...

  10. javascript 获取光标所选中的内容并插入到另一个文本框中(兼容ie和ff)

    项目中正好用到 做下笔记方便以后查找 ie获取光标的位置使用document.selection.createRange() 火狐下使用document.getElementById(id).sele ...

最新文章

  1. C#中使用的yield关键字是什么?
  2. Redis面试突击专用
  3. filebeat获取nginx的access日志配置
  4. Delphi实现类似Android锁屏的密码锁控件
  5. 杂谈--SQL SERVER版本
  6. 程序员面试金典 - 面试题 17.05. 字母与数字(哈希map+思维转换)
  7. php mvc教程 文档,PHP培训教程教你快速打造PHP MVC框架[PHP基础教程]
  8. python grid函数_(转)Python Tkinter Grid布局管理器详解
  9. mysql练习题练习
  10. 反插值法求函数方程的根(内附代码及例题)
  11. 钉钉扫码登录web网站
  12. 基于RPGMakerMV的JavaScript基础-5
  13. 移动视频录传-公网对讲APP-MCP常见操作说明
  14. matlab费曼编码输入,多点格林函数数值积分(费曼参数积分)的程序分析及应用
  15. 微信小程序覆盖map组件
  16. 基于支持向量机的谐波分析研究与实现
  17. 家居智能安防系统功能和特点介绍,如何合理化的做好家居智能安防?
  18. 三国塔防魏传java_三国塔防魏传1.6详细攻略
  19. ILSpy中baml转化为xaml的改进(三)
  20. 【工具】png去除黑色背景

热门文章

  1. 分享JTooltips 0.2beta版Demo
  2. iZotope系列音频软件如何卸载操作指南
  3. EasyRecovery---视频文件恢复技巧
  4. netstat 用法
  5. 无痕埋点(声明式)(原创)
  6. Neutron中的网络I/O虚拟化
  7. MySQL多库备份以及从多库备份中恢复某个库
  8. 【BZOJ】1303: [CQOI2009]中位数图(特殊的技巧)
  9. 如何在WEBLOGIC中设置日志输入
  10. 比尔盖茨这样审查项目 1