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