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

具体实现方法如下:

给文本输入框或富文本编辑器绑定 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 是当前获得焦点的元素,可以是输入框、文本域或富文本编辑器。如果鼠标所在位置不是文本输入框,则不做任何操作。

posted on   IT丶Hatcher  阅读(1309)  评论(0编辑  收藏  举报

相关博文:
阅读排行:
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
· Manus爆火,是硬核还是营销?
· 终于写完轮子一部分:tcp代理 了,记录一下
· 别再用vector<bool>了!Google高级工程师:这可能是STL最大的设计失误
· 单元测试从入门到精通
点击右上角即可分享
微信分享提示