There is an event for when the selection changes, selectionchange
.
The selectionchange
event is a global event, so listeners can be added on any element, although there is an experimental feature where event listeners on input elements and textarea elements only listen to changes in selection within that element. The experimental version is currently only supported in Firefox.
The selection can then be accessed through getSelection()
. In a few browsers this will return undefined if the selection is inside an input or textarea element, so if getSelection()
returns undefined, selectionStart
and selectionEnd
would work.
Example of the global selectionchange event:
let counter = 0;
document.addEventListener("selectionchange", function () {
document.querySelector("#counter").textContent = ++counter;
})
<textarea>sample text</textarea>
<p>sample text in a paragraph</p>
<p contenteditable>a paragraph you can edit</p>
<p><code>selectionchange</code> events: <span id="counter">0</span></p>