首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >如何在当前光标位置向文本区插入文本?

如何在当前光标位置向文本区插入文本?
EN

Stack Overflow用户
提问于 2012-06-18 12:37:32
回答 11查看 150.1K关注 0票数 154

我想创建一个简单的函数,将文本添加到用户光标位置的文本区域中。它需要是一个干净的函数。这只是最基本的。剩下的我会弄明白的。

EN

回答 11

Stack Overflow用户

发布于 2012-06-18 12:44:42

使用selectionStart/selectionEnd properties of the input element (也适用于<textarea> )

代码语言:javascript
复制
function insertAtCursor(myField, myValue) {
    //IE support
    if (document.selection) {
        myField.focus();
        sel = document.selection.createRange();
        sel.text = myValue;
    }
    //MOZILLA and others
    else if (myField.selectionStart || myField.selectionStart == '0') {
        var startPos = myField.selectionStart;
        var endPos = myField.selectionEnd;
        myField.value = myField.value.substring(0, startPos)
            + myValue
            + myField.value.substring(endPos, myField.value.length);
    } else {
        myField.value += myValue;
    }
}
票数 137
EN

Stack Overflow用户

发布于 2013-05-31 10:05:09

这段代码可以在jQuery 1.9+的几行代码中帮助您:http://jsfiddle.net/4MBUG/2/

代码语言:javascript
复制
$('input[type=button]').on('click', function() {
    var cursorPos = $('#text').prop('selectionStart');
    var v = $('#text').val();
    var textBefore = v.substring(0,  cursorPos);
    var textAfter  = v.substring(cursorPos, v.length);

    $('#text').val(textBefore + $(this).val() + textAfter);
});
票数 93
EN

Stack Overflow用户

发布于 2013-11-14 02:26:02

为了正确的Javascript

代码语言:javascript
复制
HTMLTextAreaElement.prototype.insertAtCaret = function (text) {
  text = text || '';
  if (document.selection) {
    // IE
    this.focus();
    var sel = document.selection.createRange();
    sel.text = text;
  } else if (this.selectionStart || this.selectionStart === 0) {
    // Others
    var startPos = this.selectionStart;
    var endPos = this.selectionEnd;
    this.value = this.value.substring(0, startPos) +
      text +
      this.value.substring(endPos, this.value.length);
    this.selectionStart = startPos + text.length;
    this.selectionEnd = startPos + text.length;
  } else {
    this.value += text;
  }
};
票数 44
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/11076975

复制
相关文章

相似问题

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