[go: up one dir, main page]

Dieser Inhalt wurde automatisch aus dem Englischen übersetzt, und kann Fehler enthalten. Erfahre mehr über dieses Experiment.

View in English Always switch to English

position

Baseline Widely available

This feature is well established and works across many devices and browser versions. It’s been available across browsers since ⁨Juli 2015⁩.

Die position-Eigenschaft von CSS legt fest, wie ein Element in einem Dokument positioniert wird. Die physikalischen Eigenschaften top, right, bottom und left sowie die flussrelativen logischen Eigenschaften inset-block-start, inset-block-end, inset-inline-start und inset-inline-end können verwendet werden, um den endgültigen Standort von positionierten Elementen zu bestimmen.

Probieren Sie es aus

position: static;
position: relative;
top: 40px;
left: 40px;
position: absolute;
inset-inline-start: 40px;
inset-block-start: 40px;
position: sticky;
top: 20px;
<section class="default-example" id="default-example">
  <div id="example-element-container">
    <p>
      In this demo you can control the <code>position</code> property for the
      yellow box.
    </p>
    <div class="box"></div>
    <div class="box" id="example-element"></div>
    <div class="box"></div>
    <p class="clear">
      To see the effect of <code>sticky</code> positioning, select the
      <code>position: sticky</code> option and scroll this container.
    </p>
    <p>
      The element will scroll along with its container, until it is at the top
      of the container (or reaches the offset specified in <code>top</code>),
      and will then stop scrolling, so it stays visible.
    </p>
    <p>
      The rest of this text is only supplied to make sure the container
      overflows, so as to enable you to scroll it and see the effect.
    </p>
    <hr />
    <p>
      Far out in the uncharted backwaters of the unfashionable end of the
      western spiral arm of the Galaxy lies a small unregarded yellow sun.
      Orbiting this at a distance of roughly ninety-two million miles is an
      utterly insignificant little blue green planet whose ape-descended life
      forms are so amazingly primitive that they still think digital watches are
      a pretty neat idea.
    </p>
  </div>
</section>
section {
  align-items: flex-start;
  overflow: auto;
}

.box {
  background-color: rgb(0 0 255 / 0.2);
  border: 3px solid blue;
  float: left;
  width: 65px;
  height: 65px;
}

.box + .box {
  margin-left: 10px;
}

.clear {
  clear: both;
  padding-top: 1em;
}

#example-element-container {
  position: relative;
  text-align: left;
}

#example-element {
  background-color: yellow;
  border: 3px solid red;
  z-index: 1;
}

Syntax

css
position: static;
position: relative;
position: absolute;
position: fixed;
position: sticky;

/* Global values */
position: inherit;
position: initial;
position: revert;
position: revert-layer;
position: unset;

Werte

static

Das Element wird gemäß dem Normalfluss des Dokuments positioniert. Die Eigenschaften top, right, bottom, left und z-index haben keine Wirkung. Dies ist der Standardwert.

relative

Das Element wird gemäß dem normalen Fluss des Dokuments positioniert und dann relativ zu sich selbst basierend auf den Werten von top, right, bottom und left versetzt. Die Versetzung hat keine Auswirkungen auf die Position anderer Elemente; daher ist der Platz, der dem Element im Seitenlayout zugewiesen wird, derselbe, als ob die Position static wäre.

Dieser Wert erzeugt einen neuen Stapeldurchlauf, wenn der Wert von z-index nicht auto ist. Sein Effekt auf die Elemente table-*-group, table-row, table-column, table-cell und table-caption ist nicht definiert.

absolute

Das Element wird aus dem normalen Dokumentfluss entfernt und es wird kein Platz für das Element im Seitenlayout erstellt. Das Element wird relativ zu seinem nächsten positionierten Vorfahren (falls vorhanden) oder zum initialen Containment-Block positioniert. Seine endgültige Position wird durch die Werte von top, right, bottom und left bestimmt.

Dieser Wert erzeugt einen neuen Stapeldurchlauf, wenn der Wert von z-index nicht auto ist. Die Ränder von absolut positionierten Boxen kollabieren nicht mit anderen Rändern.

fixed

Das Element wird aus dem normalen Dokumentfluss entfernt und es wird kein Platz für das Element im Seitenlayout erstellt. Das Element wird relativ zu seinem initialen Containment-Block positioniert, das im Fall visueller Medien das Viewport ist. Seine endgültige Position wird durch die Werte von top, right, bottom und left bestimmt.

Dieser Wert erzeugt immer einen neuen Stapeldurchlauf. In gedruckten Dokumenten wird das Element auf jeder Seite an derselben Position platziert.

sticky

Das Element wird gemäß dem normalen Fluss des Dokuments positioniert und dann relativ zu seinem nächsten scrollbaren Vorfahren und Containment-Block (nächster Block-Level-Vorfahre) einschließlich tabellenbezogener Elemente basierend auf den Werten von top, right, bottom und left versetzt. Die Versetzung hat keine Auswirkungen auf die Position anderer Elemente.

Dieser Wert erzeugt immer einen neuen Stapeldurchlauf. Beachten Sie, dass ein sticky-Element an seinem nächsten Vorfahr "klebt", der einen "Scrollmechanismus" hat (erstellt, wenn overflow hidden, scroll, auto oder overlay ist), auch wenn dieser Vorfahr nicht der tatsächlich nächste scrollbare Vorfahr ist.

Hinweis: Mindestens eine inset-Eigenschaft (top, inset-block-start, right, inset-inline-end, etc.) muss auf einen Nicht-auto-Wert gesetzt werden, damit die Achse, auf der das Element sticky gemacht werden soll, funktioniert. Wenn beide inset-Eigenschaften für eine Achse auf auto gesetzt sind, verhält sich der sticky-Wert auf jener Achse wie relative.

Beschreibung

Arten der Positionierung

  • Ein positioniertes Element ist ein Element, dessen berechneter position-Wert entweder relative, absolute, fixed oder sticky ist. (Mit anderen Worten, es ist alles außer static.)
  • Ein relativ positioniertes Element ist ein Element, dessen berechneter position-Wert relative ist. Die Eigenschaften top und bottom geben den vertikalen Versatz von der normalen Position an; die Eigenschaften left und right geben den horizontalen Versatz an.
  • Ein absolut positioniertes Element ist ein Element, dessen berechneter position-Wert absolute oder fixed ist. Die Eigenschaften top, right, bottom und left geben die Abstände von den Kanten des Containment-Blocks des Elements an. (Der Containment-Block ist der Vorfahre, relativ zu dem das Element positioniert wird.) Wenn das Element Ränder hat, werden sie zum Versatz hinzugerechnet. Das Element etabliert einen neuen Block-Formatierungskontext (BFC) für seinen Inhalt.
  • Ein stickly positioniertes Element ist ein Element, dessen berechneter position-Wert sticky ist. Es wird so behandelt, als wäre es relativ positioniert, bis sein Containment-Block einen bestimmten Schwellenwert überschreitet (wie das Setzen von top auf einen Wert ungleich auto) innerhalb seiner Flusswurzel (oder des Containers, in dem es scrollt), an welchem Punkt es als "festgeklebt" behandelt wird, bis es den entgegengesetzten Rand seines Containment-Blocks erreicht.

In den meisten Fällen werden absolut positionierte Elemente, die height und width auf auto gesetzt haben, so dimensioniert, dass sie ihren Inhalt aufnehmen. Nicht-ersetzte, absolut positionierte Elemente können jedoch so eingestellt werden, dass sie den verfügbaren vertikalen Raum ausfüllen, indem sowohl top als auch bottom angegeben werden und height nicht spezifiziert wird (also auto). Ebenso können sie so eingestellt werden, dass sie den verfügbaren horizontalen Raum ausfüllen, indem sowohl left als auch right angegeben werden und width als auto gelassen wird.

Außer im oben beschriebenen Fall (absolut positionierter Elemente, die den verfügbaren Raum ausfüllen):

  • Wenn sowohl top als auch bottom angegeben sind (technisch nicht auto), hat top Vorrang.
  • Wenn sowohl left als auch right angegeben sind, hat left Vorrang, wenn direction ltr ist (Englisch, horizontales Japanisch, usw.) und right hat Vorrang, wenn direction rtl ist (Persisch, Arabisch, Hebräisch, usw.).

Barrierefreiheit

Stellen Sie sicher, dass Elemente, die mit einem absolute oder fixed Wert positioniert sind, andere Inhalte nicht verdecken, wenn die Seite zum Erhöhen der Textgröße vergrößert wird.

Leistung & Barrierefreiheit

Scrollen von Elementen, die fixed oder sticky enthalten, kann Leistungs- und Barriereprobleme verursachen. Beim Scrollen muss der Browser den sticky oder feststehenden Inhalt an einem neuen Ort neu zeichnen. Abhängig vom Inhalt, der neu gezeichnet werden muss, der Browserleistung und der Geschwindigkeit der Geräteverarbeitung, kann der Browser möglicherweise keine Neuzeichnungen bei 60 FPS verwalten. Ein solches Szenario kann zu Stocken und, noch wichtiger, zu Barriereproblemen für Personen mit Empfindlichkeiten führen. Eine Lösung besteht darin, will-change: transform zu den positionierten Elementen hinzuzufügen, um das Element in seiner eigenen Ebene zu rendern. Dies verbessert die Neuzeichnungsgeschwindigkeit und damit die Leistung und Barrierefreiheit.

Formale Definition

Anfangswertstatic
Anwendbar aufalle Elemente
VererbtNein
Berechneter Wertwie angegeben
Animationstypdiskret
Erstellt StapelkontextJa

Formale Syntax

position = 
static |
relative |
absolute |
sticky |
fixed |
<running()>

<running()> =
running( <custom-ident> )

Beispiele

Relative Positionierung

Relativ positionierte Elemente sind um einen bestimmten Betrag von ihrer normalen Position im Dokument versetzt, jedoch ohne dass die Versetzung andere Elemente beeinflusst. Im untenstehenden Beispiel ist zu beachten, wie die anderen Elemente angeordnet sind, als ob "Two" den Raum seiner normalen Position einnimmt.

HTML

html
<div class="box" id="one">One</div>
<div class="box" id="two">Two</div>
<div class="box" id="three">Three</div>
<div class="box" id="four">Four</div>

CSS

css
* {
  box-sizing: border-box;
}

.box {
  display: inline-block;
  width: 100px;
  height: 100px;
  background: red;
  color: white;
}

#two {
  position: relative;
  top: 20px;
  left: 20px;
  background: blue;
}

Absolute Positionierung

Elemente, die relativ positioniert sind, bleiben im normalen Fluss des Dokuments. Im Gegensatz dazu wird ein absolut positioniertes Element aus dem Fluss genommen; daher werden andere Elemente so positioniert, als ob es nicht existieren würde. Das absolut positionierte Element wird relativ zu seinem nächstgelegenen positionierten Vorfahren (d.h. dem nächsten Vorfahren, der nicht static ist) positioniert. Wenn es keinen positionierten Vorfahren gibt, wird es relativ zum ICB (initialer Containment-Block) positioniert, das der Containment-Block des Wurzelelements des Dokuments ist.

HTML

html
<h1>Absolute positioning</h1>

<p>
  I am a basic block level element. My adjacent block level elements sit on new
  lines below me.
</p>

<p class="positioned">
  By default we span 100% of the width of our parent element, and we are as tall
  as our child content. Our total width and height is our content + padding +
  border width/height.
</p>

<p>
  We are separated by our margins. Because of margin collapsing, we are
  separated by the width of one of our margins, not both.
</p>

<p>
  inline elements <span>like this one</span> and <span>this one</span> sit on
  the same line as one another, and adjacent text nodes, if there is space on
  the same line. Overflowing inline elements
  <span>wrap onto a new line if possible — like this one containing text</span>,
  or just go on to a new line if not, much like this image will do:
  <img src="https://mdn.github.io/shared-assets/images/examples/long.jpg" />
</p>

CSS

css
* {
  box-sizing: border-box;
}

body {
  width: 500px;
  margin: 0 auto;
}

p {
  background: aqua;
  border: 3px solid blue;
  padding: 10px;
  margin: 10px;
}

span {
  background: red;
  border: 1px solid black;
}

.positioned {
  position: absolute;
  background: yellow;
  inset-block-start: 30px;
  inset-inline-start: 30px;
}

Ergebnis

Feste Positionierung

Feste Positionierung ist der absoluten Positionierung ähnlich, mit dem Unterschied, dass der Containment-Block des Elements der initiale Containment-Block ist, der vom Viewport etabliert wird, es sei denn, ein Vorfahre hat die Eigenschaft transform, perspective oder filter auf etwas anderes als none gesetzt (siehe festes Positionierungs-Containment-Block), was dann dazu führt, dass dieser Vorfahre den Platz des Containment-Blocks des Elements einnimmt. Dies kann verwendet werden, um ein "schwebendes" Element zu erstellen, das unabhängig vom Scrollen an derselben Position bleibt. Im untenstehenden Beispiel ist die Box "One" 80 Pixel von der Oberseite der Seite und 10 Pixel von links fixiert. Selbst nach dem Scrollen bleibt sie an derselben Stelle relativ zum Viewport. Auch wenn die Eigenschaft will-change auf transform gesetzt wird, wird ein neuer Containment-Block etabliert.

HTML

html
<div class="outer">
  <p>
    Lorem ipsum dolor sit amet, consectetur adipiscing elit. Nam congue tortor
    eget pulvinar lobortis. Vestibulum ante ipsum primis in faucibus orci luctus
    et ultrices posuere cubilia Curae; Nam ac dolor augue. Pellentesque mi mi,
    laoreet et dolor sit amet, ultrices varius risus. Nam vitae iaculis elit.
    Aliquam mollis interdum libero. Sed sodales placerat egestas. Vestibulum ut
    arcu aliquam purus viverra dictum vel sit amet mi. Duis nisl mauris, aliquam
    sit amet luctus eget, dapibus in enim. Sed velit augue, pretium a sem
    aliquam, congue porttitor tortor. Sed tempor nisl a lorem consequat, id
    maximus erat aliquet. Sed sagittis porta libero sed condimentum. Aliquam
    finibus lectus nec ante congue rutrum. Curabitur quam quam, accumsan id
    ultrices ultrices, tempor et tellus.
  </p>
  <p>
    Lorem ipsum dolor sit amet, consectetur adipiscing elit. Nam congue tortor
    eget pulvinar lobortis. Vestibulum ante ipsum primis in faucibus orci luctus
    et ultrices posuere cubilia Curae; Nam ac dolor augue. Pellentesque mi mi,
    laoreet et dolor sit amet, ultrices varius risus. Nam vitae iaculis elit.
    Aliquam mollis interdum libero. Sed sodales placerat egestas. Vestibulum ut
    arcu aliquam purus viverra dictum vel sit amet mi. Duis nisl mauris, aliquam
    sit amet luctus eget, dapibus in enim. Sed velit augue, pretium a sem
    aliquam, congue porttitor tortor. Sed tempor nisl a lorem consequat, id
    maximus erat aliquet. Sed sagittis porta libero sed condimentum. Aliquam
    finibus lectus nec ante congue rutrum. Curabitur quam quam, accumsan id
    ultrices ultrices, tempor et tellus.
  </p>
  <div class="box" id="one">One</div>
</div>

CSS

css
* {
  box-sizing: border-box;
}

.box {
  width: 100px;
  height: 100px;
  background: red;
  color: white;
}

#one {
  position: fixed;
  top: 80px;
  left: 10px;
  background: blue;
}

.outer {
  width: 500px;
  height: 300px;
  overflow: scroll;
  padding-left: 150px;
}

Ergebnis

Sticky Positionierung

Die folgende CSS-Regel positioniert das Element mit der ID one relativ, bis das Viewport so gescrollt wird, dass das Element 10 Pixel von der Oberseite entfernt ist. Jenseits dieses Schwellenwertes wird das Element fest an 10 Pixel von der Oberseite fixiert.

css
#one {
  position: sticky;
  top: 10px;
}

Liste mit sticken Überschriften

Eine häufige Verwendung für sticky Positionierung ist für die Überschriften in einer alphabetisierten Liste. Die "B"-Überschrift wird direkt unter den Elementen erscheinen, die mit "A" beginnen, bis sie vom Bildschirm gescrollt werden. Statt mit dem restlichen Inhalt vom Bildschirm zu gleiten, bleibt die "B"-Überschrift dann oben am Viewport fixiert, bis alle "B"-Elemente vom Bildschirm gescrollt sind, zu welchem Zeitpunkt sie von der "C"-Überschrift überdeckt wird, und so weiter.

Sie müssen einen Schwellenwert mit mindestens einem der Elemente top, right, bottom oder left angeben, damit die sticky Positionierung wie erwartet funktioniert. Andernfalls lässt sie sich nicht von der relativen Positionierung unterscheiden.

HTML
html
<dl>
  <div>
    <dt>A</dt>
    <dd>Andrew W.K.</dd>
    <dd>Apparat</dd>
    <dd>Arcade Fire</dd>
    <dd>At The Drive-In</dd>
    <dd>Aziz Ansari</dd>
  </div>
  <div>
    <dt>C</dt>
    <dd>Chromeo</dd>
    <dd>Common</dd>
    <dd>Converge</dd>
    <dd>Crystal Castles</dd>
    <dd>Cursive</dd>
  </div>
  <div>
    <dt>E</dt>
    <dd>Explosions In The Sky</dd>
  </div>
  <div>
    <dt>T</dt>
    <dd>Ted Leo &amp; The Pharmacists</dd>
    <dd>T-Pain</dd>
    <dd>Thrice</dd>
    <dd>TV On The Radio</dd>
    <dd>Two Gallants</dd>
  </div>
</dl>
CSS
css
* {
  box-sizing: border-box;
}

dl > div {
  background: white;
  padding-top: 24px;
}

dt {
  background: #b8c1c8;
  border-bottom: 1px solid #989ea4;
  border-top: 1px solid #717d85;
  color: white;
  font:
    bold 18px/21px "Helvetica",
    "Arial",
    sans-serif;
  margin: 0;
  padding: 2px 0 0 12px;
  position: -webkit-sticky;
  position: sticky;
  top: -1px;
}

dd {
  font:
    bold 20px/45px "Helvetica",
    "Arial",
    sans-serif;
  margin: 0;
  padding-left: 12px;
  white-space: nowrap;
}

dd + dd {
  border-top: 1px solid #cccccc;
}
Ergebnis

Sticky-Position mit allen eingestellten Inset-Grenzen

Das folgende Beispiel zeigt das Verhalten eines Elements, wenn alle Inset-Grenzen festgelegt sind. Hier haben wir zwei Glühbirnen-Emojis in einem Absatz. Die Glühbirnen verwenden eine sticky-Positionierung, und die Inset-Grenzen sind mit 50px von oben, 100px von rechts, 50px von unten und 50px von links angegeben. Ein grauer Hintergrund auf dem übergeordneten Div-Element markiert den Inset-Bereich.

HTML
html
Use scrollbars to put the light bulbs(💡) in the right place in the following
text:
<div>
  <p>
    The representation of an idea by a light bulb(<span class="bulb">💡</span>)
    is a commonly used metaphor that symbolizes the moment of inspiration or the
    birth of a new idea. The association between a light bulb and an idea can be
    traced back to the invention of the incandescent light bulb(<span
      class="bulb"
      >💡</span
    >) by Thomas Edison in the late 19th century. The light bulb is a powerful
    symbol because it represents illumination, clarity, and the sudden
    brightening of one's thoughts or understanding. When someone has an idea, it
    is often described as a light bulb turning on in their mind, signifying a
    moment of insight or creativity. The image of a light bulb also suggests the
    idea of energy, power, and the potential for growth and development.
  </p>
</div>
CSS
css
.bulb {
  position: sticky;
  inset: 50px 100px;
}

div {
  /* mark area defined by the inset boundaries using gray color */
  background: linear-gradient(#99999999, #99999999) 100px 50px / 192px 100px
    no-repeat;
}
Ergebnis

Wenn Sie beide Glühbirnen an ihren richtigen Platz stellen, werden Sie feststellen, dass sie relativ innerhalb des Inset-Bereichs positioniert sind. Wenn Sie sie aus dem Inset-Bereich heraus bewegen, werden sie in die entsprechende Richtung an die Inset-Grenze fixiert (sticky).

Spezifikationen

Specification
CSS Positioned Layout Module Level 3
# position-property

Browser-Kompatibilität

Siehe auch