一尘不染

JavaScript如何从头开始以字符为单位在文本区域中插入符号的列(不是像素)位置?

javascript

<textarea>使用JavaScript的情况下,如何获得插入符的位置?

例如: This is| a text

这应该返回7

您如何获得它来返回光标/选择周围的字符串?

例如:'This is', '', ' a text'

如果突出显示单词“ is”,则它将返回'This ', 'is', ' a text'


阅读 310

收藏
2020-04-23

共1个答案

一尘不染

使用Firefox,Safari(和其他基于Gecko的浏览器),您可以轻松地使用textarea.selectionStart,但对于IE则无法使用,因此您必须执行以下操作:

function getCaret(node) {
  if (node.selectionStart) {
    return node.selectionStart;
  } else if (!document.selection) {
    return 0;
  }

  var c = "\001",
      sel = document.selection.createRange(),
      dul = sel.duplicate(),
      len = 0;

  dul.moveToElementText(node);
  sel.text = c;
  len = dul.text.indexOf(c);
  sel.moveStart('character',-1);
  sel.text = "";
  return len;
}

我还建议您检查jQueryFieldSelection插件,它可以使您做到这一点以及更多…

编辑: 我实际上重新实现了上面的代码:

function getCaret(el) { 
  if (el.selectionStart) { 
    return el.selectionStart; 
  } else if (document.selection) { 
    el.focus();

    var r = document.selection.createRange(); 
    if (r == null) { 
      return 0; 
    }

    var re = el.createTextRange(), 
        rc = re.duplicate(); 
    re.moveToBookmark(r.getBookmark()); 
    rc.setEndPoint('EndToStart', re);

    return rc.text.length; 
  }  
  return 0; 
}
2020-04-23