Selection

open class Selection(source)

A Selection object represents the range of text selected by the user or the current position of the caret. Each document is associated with a unique selection object, which can be retrieved by document.getSelection() or window.getSelection() and then be examined and modified.

MDN Reference

Properties

Link copied to clipboard

The Selection.anchorNode read-only property returns the Node in which the selection begins. It can return null if selection never existed in the document (e.g., an iframe that was never clicked on, or the node belongs to another document tree).

Link copied to clipboard

The Selection.anchorOffset read-only property returns the number of characters that the selection's anchor is offset within the Selection.anchorNode if said node is of type Text, CDATASection or Comment.

Link copied to clipboard

The direction read-only property of the Selection interface is a string that provides the direction of the current selection.

Link copied to clipboard

The Selection.focusNode read-only property returns the Node in which the selection ends. It can return null if selection never existed in the document (e.g., an iframe that was never clicked on, or the node belongs to another document tree).

Link copied to clipboard

The Selection.focusOffset read-only property returns the number of characters that the selection's focus is offset within the Selection.focusNode if said node is of type Text, CDATASection or Comment.

Link copied to clipboard

The Selection.isCollapsed read-only property returns a boolean value which indicates whether or not there is currently any text selected. No text is selected when the selection's start and end points are at the same position in the content.

Link copied to clipboard

The Selection.rangeCount read-only property returns the number of ranges in the selection.

Link copied to clipboard

The type read-only property of the Selection interface returns a string describing the type of the current selection.

Functions

Link copied to clipboard
fun addRange(range: Range)

The Selection.addRange() method adds a Range to a Selection.

Link copied to clipboard
fun collapse(node: Node?, offset: Int = definedExternally)

The Selection.collapse() method collapses the current selection to a single point. The document is not modified. If the content is focused and editable, the caret will blink there.

Link copied to clipboard

The Selection.collapseToEnd() method collapses the selection to the end of the last range in the selection. If the content of the selection is focused and editable, the caret will blink there.

Link copied to clipboard

The Selection.collapseToStart() method collapses the selection to the start of the first range in the selection. If the content of the selection is focused and editable, the caret will blink there.

Link copied to clipboard
fun containsNode(node: Node, allowPartialContainment: Boolean = definedExternally): Boolean

The Selection.containsNode() method indicates whether a specified node is part of the selection.

Link copied to clipboard

The deleteFromDocument() method of the Selection interface invokes the Range.deleteContents() method on the selected Range.

Link copied to clipboard
fun empty()

The Selection.empty() method removes all ranges from the selection, leaving the anchorNode and focusNode properties equal to null and nothing selected. When this method is called, a selectionchange event is fired at the document.

Link copied to clipboard
fun extend(node: Node, offset: Int = definedExternally)

The Selection.extend() method moves the focus of the selection to a specified point. The anchor of the selection does not move. The selection will be from the anchor to the new focus, regardless of direction.

Link copied to clipboard

The Selection.getComposedRanges() method returns an array of StaticRange objects representing the current selection ranges, and can return ranges that potentially cross shadow boundaries.

Link copied to clipboard
fun getRangeAt(index: Int): Range

The getRangeAt() method of the Selection interface returns a range object representing a currently selected range.

Link copied to clipboard
fun modify(alter: String = definedExternally, direction: String = definedExternally, granularity: String = definedExternally)

The Selection.modify() method applies a change to the current selection or cursor position, using simple textual commands.

Link copied to clipboard

The Selection.removeAllRanges() method removes all ranges from the selection, leaving the anchorNode and focusNode properties equal to null and nothing selected. When this method is called, a selectionchange event is fired at the document.

Link copied to clipboard
fun removeRange(range: Range)

The Selection.removeRange() method removes a range from a selection.

Link copied to clipboard

The Selection.selectAllChildren() method adds all the children of the specified node to the selection. Previous selection is lost.

Link copied to clipboard
fun setBaseAndExtent(anchorNode: Node, anchorOffset: Int, focusNode: Node, focusOffset: Int)

The setBaseAndExtent() method of the Selection interface sets the selection to be a range including all or parts of two specified DOM nodes, and any content located between them.

Link copied to clipboard
fun setPosition(node: Node?, offset: Int = definedExternally)

The Selection.setPosition() method collapses the current selection to a single point. The document is not modified. If the content is focused and editable, the caret will blink there.