使用 window.getSelection() 和 getRangeAt() 方法来获取鼠标光标前的字符串。

发布时间 2023-04-07 11:36:47作者: IT丶Hatcher

具体实现方法如下:

给文本输入框或富文本编辑器绑定 mouseup 事件,监听鼠标松开的动作。
在事件处理函数中,先判断当前文本框是否获得了焦点(即用户在此次点击之前,已经在该文本框内部输入过字符)。
如果已经获得了焦点,则获取当前选区(Selection)对象。
利用 getRangeAt() 方法获取光标所在的范围(Range)对象。其中, Range 对象的 startContainer 属性表示光标前面的节点,startOffset 属性表示光标前面的偏移量。
利用 Range 对象的 toString() 方法获取光标前面的字符串。
例如,以下代码可以获取光标前面的字符串:

document.addEventListener('mouseup', function () {
  const activeEl = document.activeElement;
  if (activeEl.tagName === 'INPUT' || activeEl.tagName === 'TEXTAREA' || activeEl.contentEditable === 'true') {
    const selection = window.getSelection();
    if (selection.rangeCount > 0) {
      const range = selection.getRangeAt(0);
      const str = range.startContainer.textContent.substr(0, range.startOffset);
      console.log(str);
    }
  }
});

以上代码会在鼠标松开的时候,在控制台输出光标前面的字符串。其中, activeEl 是当前获得焦点的元素,可以是输入框、文本域或富文本编辑器。如果鼠标所在位置不是文本输入框,则不做任何操作。