使用 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 2023-04-07 11:31 IT丶Hatcher 阅读(1309) 评论(0) 编辑 收藏 举报
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
· Manus爆火,是硬核还是营销?
· 终于写完轮子一部分:tcp代理 了,记录一下
· 别再用vector<bool>了!Google高级工程师:这可能是STL最大的设计失误
· 单元测试从入门到精通