首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >jQuery设置光标在文本区域的位置

jQuery设置光标在文本区域的位置
EN

Stack Overflow用户
提问于 2009-01-31 16:39:11
回答 15查看 363.9K关注 0票数 447

如何使用jQuery设置文本字段中的光标位置?我有一个包含内容的文本字段,当用户聚焦于该字段时,我希望用户的光标定位在特定的偏移量上。代码看起来应该是这样的:

代码语言:javascript
运行
复制
$('#input').focus(function() {
  $(this).setCursorPosition(4);
});

这个setCursorPosition函数的实现是什么样子的?如果您有一个包含内容abcdefg的文本字段,则此调用将导致光标被定位为以下位置:abcd**x**efg。

Java有类似的功能,setCaretPosition。对于javascript是否存在类似的方法?

更新:我修改了CMS的代码以使用jQuery,如下所示:

代码语言:javascript
运行
复制
new function($) {
  $.fn.setCursorPosition = function(pos) {
    if (this.setSelectionRange) {
      this.setSelectionRange(pos, pos);
    } else if (this.createTextRange) {
      var range = this.createTextRange();
      range.collapse(true);
      if(pos < 0) {
        pos = $(this).val().length + pos;
      }
      range.moveEnd('character', pos);
      range.moveStart('character', pos);
      range.select();
    }
  }
}(jQuery);
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/499126

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档