anchor

Nicht standardisiert: Diese Funktion ist nicht standardisiert und befindet sich nicht auf dem Weg zur Standardisierung. Verwenden Sie sie nicht auf Produktionsseiten, die dem Web ausgesetzt sind: Sie funktioniert nicht für alle Benutzer. Es kann auch große Inkompatibilitäten zwischen Implementierungen geben, und das Verhalten kann sich in Zukunft ändern.

Experimentell: Dies ist eine experimentelle Technologie
Überprüfen Sie die Browser-Kompatibilitätstabelle sorgfältig vor der Verwendung auf produktiven Webseiten.

Das anchor-Globale Attribut wird verwendet, um ein positioniertes Element mit einem Ankerelement zu verknüpfen. Der Wert des Attributs ist der id-Wert des Elements, an das Sie das positionierte Element ankern möchten. Das Element kann dann mit CSS-Ankerpositionierung positioniert werden.

Hinweis: Alternativ können Sie ein positioniertes Element über CSS mit einem Ankerelement verknüpfen, indem Sie die anchor-name und position-anchor Eigenschaften verwenden. Wenn beide Ankerechniken auf dasselbe Element angewendet werden, hat die CSS-Technik Vorrang vor der HTML-Technik.

Beispiele

Grundlegende Verwendung des anchor-Attributs

Das folgende Beispiel verwendet HTML, um ein positioniertes Element mit einem Anker zu verknüpfen. CSS wird dann verwendet, um das positionierte Element rechts vom Anker zu verbinden.

HTML

Wir erstellen ein <div>-Element mit einer id von example-anchor. Dies ist unser Ankerelement. Dann fügen wir ein weiteres <div> hinzu, das Attribut anchor ist auf example-anchor gesetzt. Damit wird das erste <div> als Anker für das zweite <div> bezeichnet und die beiden werden miteinander verbunden.

Wir fügen auch etwas Fülltext um die beiden <div>s hinzu, um den <body> größer zu machen, damit er scrollen kann.

html
<p>
  Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor
  incididunt ut labore et dolore magna aliqua. Dui nunc mattis enim ut tellus
  elementum sagittis vitae et.
</p>

<div class="anchor" id="example-anchor">⚓︎</div>

<div class="infobox" anchor="example-anchor">
  <p>This is an information box.</p>
</div>

<p>
  Nisi quis eleifend quam adipiscing vitae proin sagittis nisl rhoncus. In arcu
  cursus euismod quis viverra nibh cras pulvinar. Vulputate ut pharetra sit amet
  aliquam.
</p>

<p>
  Malesuada nunc vel risus commodo viverra maecenas accumsan lacus. Vel elit
  scelerisque mauris pellentesque pulvinar pellentesque habitant morbi
  tristique. Porta lorem mollis aliquam ut porttitor. Turpis cursus in hac
  habitasse platea dictumst quisque. Dolor sit amet consectetur adipiscing elit.
  Ornare lectus sit amet est placerat. Nulla aliquet porttitor lacus luctus
  accumsan.
</p>

CSS

Wir verwenden CSS, um das infobox-Element in ein ankerpositioniertes Element zu verwandeln und relativ zu seinem Anker zu positionieren. Wir setzen:

  • Die position-Eigenschaft auf fixed, um es in ein positioniertes Element zu verwandeln, damit es relativ zur Position des Ankers positioniert werden kann.
  • Die left-Eigenschaft auf eine anchor()-Funktion mit einem Wert von right. Dies verbindet das positionierte Element mit seinem Anker und positioniert seine linke Kante bündig zur rechten Kante des Ankers.
  • Die align-self-Eigenschaft auf anchor-center. Dies bewirkt, dass die Infobox zentral zum Zentrum des Ankers in Richtung der Inline-Richtung ausgerichtet wird.
  • margin-left auf 10px, um Platz zwischen dem ankerpositionierten Element und seinem Anker zu schaffen.
css
.infobox {
  position: fixed;
  left: anchor(right);
  align-self: anchor-center;
  margin-left: 10px;
}

Ergebnis

Scrollen Sie das Beispiel, um zu sehen, wie die Infobox an den Anker gebunden ist. Wenn das anchor-Attribut unterstützt wird, wird die Infobox rechts vom Anker fixiert. Andernfalls wird die Infobox am Viewport fixiert.

Spezifikationen

Dieses Attribut ist derzeit nicht Teil der HTML-Spezifikation. Lesen Sie die Diskussion über die Hinzufügung des anchor-Attributs unter https://github.com/whatwg/html/pull/9144.

Browser-Kompatibilität

BCD tables only load in the browser

Siehe auch