Range: setStart() Methode
Baseline Widely available
This feature is well established and works across many devices and browser versions. It’s been available across browsers since March 2017.
Die Range.setStart()
Methode setzt die Startposition eines
Range
.
Wenn der startNode
ein Node
vom Typ Text
,
Comment
oder CDataSection
ist, dann ist startOffset
die Anzahl der Zeichen vom Beginn des startNode
. Für andere
Node
-Typen ist startOffset
die Anzahl der Kindknoten
vom Anfang des startNode
.
Das Setzen des Startpunkts unterhalb (weiter im Dokument) des Endpunkts führt zu einem kollabierten Bereich, bei dem beide, Start- und Endpunkte, auf die angegebene Startposition gesetzt sind.
Syntax
setStart(startNode, startOffset)
Parameter
startNode
startOffset
-
Eine ganze Zahl größer oder gleich null, die den Versatz für den Beginn des
Range
vom Start desstartNode
darstellt.
Rückgabewert
Keiner (undefined
).
Beispiele
Teil eines Elements hervorheben
Dieses Beispiel verwendet die Methoden Range.setStart()
und Range.setEnd()
,
um einen Teil einer Adresse zu einem Bereich hinzuzufügen. Der ausgewählte Bereich wird dann
mit Range.surroundContents()
hervorgehoben.
Die Adresse enthält neun Knoten: fünf Textknoten und vier <br>
Elemente.
HTML
<p id="address">
Wyatt Earp<br />
101 E. Main St.<br />
Dodge City, KS<br />
67801<br />
USA
</p>
<hr />
<p>Nodes in the original address:</p>
<ol id="log"></ol>
JavaScript
const address = document.getElementById("address");
const log = document.getElementById("log");
// Log info
address.childNodes.forEach((node) => {
const li = document.createElement("li");
li.textContent = `${node.nodeName}, ${node.nodeValue}`;
log.appendChild(li);
});
// Highlight the street and city
const startOffset = 2; // Start at third node: 101 E. Main St.
const endOffset = 5; // End at fifth node: Dodge City, KS
const range = document.createRange();
range.setStart(address, startOffset);
range.setEnd(address, endOffset);
const mark = document.createElement("mark");
range.surroundContents(mark);
Ergebnis
Zeichen aus einem Textknoten abrufen
Dieses Beispiel verwendet die Methoden Range.setStart()
und Range.setEnd()
um den Inhalt eines Bereichs zu definieren. Der resultierende Bereich enthält die ersten
bis fünften Zeichen innerhalb eines Textknotens.
HTML
<p id="content">0123456789</p>
<p id="log"></p>
JavaScript
const element = document.getElementById("content");
const textNode = element.childNodes[0];
const range = document.createRange();
range.setStart(textNode, 0); // Start at first character
range.setEnd(textNode, 5); // End at fifth character
document.getElementById("log").textContent = range;
Ergebnis
Spezifikationen
Specification |
---|
DOM # dom-range-setstart |
Browser-Kompatibilität
BCD tables only load in the browser