1. Web
  2. CSS
  3. Guides
  4. Animations

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

View in English Always switch to English

CSS-Animationen

Das CSS-Animationsmodul ermöglicht es Ihnen, die Werte von CSS-Eigenschaften wie background-position und transform im Laufe der Zeit durch die Verwendung von Keyframes zu animieren. Jedes Keyframe beschreibt, wie das animierte Element zu einem bestimmten Zeitpunkt während der Animationssequenz dargestellt werden soll. Sie können die Eigenschaften im Animationsmodul verwenden, um die Dauer, die Anzahl der Wiederholungen, den verzögerten Start und andere Aspekte einer Animation zu steuern.

Animationen in Aktion

Um die Animation im untenstehenden Feld anzusehen, klicken Sie auf das Kontrollkästchen 'Animation abspielen' oder fahren Sie mit dem Cursor über das Feld. Wenn die Animation aktiv ist, ändert die Wolke oben ihre Form, Schneeflocken fallen, und der Schneepegel am Boden steigt. Um die Animation zu pausieren, deaktivieren Sie das Kontrollkästchen oder bewegen Sie Ihren Cursor weg von dem Feld.

<!-- See aria-label: https://developer.mozilla.org/en-US/docs/Web/Accessibility/ARIA/Reference/Attributes/aria-label -->
<input
 type="checkbox"
 id="animate"
 aria-label="Toggle the play state of the animation" />
<label for="animate">the animation</label>
<div class="root">
 <i></i><i></i><i></i><i></i><i></i><i></i><i></i><i></i><i></i><i></i><i></i
 ><i></i><i></i><i></i><i></i><i></i><i></i><i></i><i></i><i></i><i></i><i></i
 ><i></i><i></i><i></i><i></i><i></i><i></i><i></i><i></i><i></i><i></i><i></i
 ><i></i><i></i><i></i><i></i><i></i><i></i><i></i><i></i><i></i><i></i><i></i
 ><i></i><i></i><i></i><i></i><i></i><i></i><i></i><i></i><i></i>
 <div class="cloud"></div>
 <div class="ground"></div>
</div>
i {
 display: inline-block;
 height: 16px;
 width: 16px;
 border-radius: 50%;
 animation: falling 3s linear 0s infinite backwards;
 /* Snowflakes are made with CSS linear gradients (https://developer.mozilla.org/en-US/docs/Web/CSS/Guides/Images/Using_gradients) */
 background-image:
 linear-gradient(180deg, transparent 40%, white 40% 60%, transparent 60%),
 linear-gradient(90deg, transparent 40%, white 40% 60%, transparent 60%),
 linear-gradient(45deg, transparent 43%, white 43% 57%, transparent 57%),
 linear-gradient(135deg, transparent 43%, white 43% 57%, transparent 57%);
}
i:nth-of-type(4n) {
 /* Using tree structural pseudo-classes to create randomness - https://developer.mozilla.org/en-US/docs/Web/CSS/Reference/Selectors/:nth-of-type */
 height: 30px;
 width: 30px;
 transform-origin: right -30px;
}
i:nth-of-type(4n + 1) {
 height: 24px;
 width: 24px;
 transform-origin: left 30px;
}
i:nth-of-type(4n + 2) {
 height: 10px;
 width: 10px;
 transform-origin: -30px 0;
}
i:nth-of-type(4n + 3) {
 height: 40px;
 width: 40px;
 transform-origin: -50px 0;
}
i:nth-of-type(4n) {
 animation-duration: 5.3s;
 animation-iteration-count: 12;
 transform-origin: -10px -20px;
}
i:nth-of-type(4n + 1) {
 animation-duration: 3.1s;
 animation-iteration-count: 20;
 transform-origin: 10px -20px;
}
i:nth-of-type(4n + 2) {
 animation-duration: 1.7s;
 animation-iteration-count: 35;
 transform-origin: right -20px;
}
i:nth-of-type(3n) {
 animation-delay: 2.3s;
}
i:nth-of-type(3n + 1) {
 animation-delay: 1.5s;
}
i:nth-of-type(3n + 2) {
 animation-delay: 3.4s;
}
i:nth-of-type(5n) {
 animation-timing-function: ease-in-out;
}
i:nth-of-type(5n + 1) {
 animation-timing-function: ease-out;
}
i:nth-of-type(5n + 2) {
 animation-timing-function: ease;
}
i:nth-of-type(5n + 3) {
 animation-timing-function: ease-in;
}
i:nth-of-type(5n + 4) {
 animation-timing-function: linear;
}
i:nth-of-type(11n) {
 animation-timing-function: cubic-bezier(0.2, 0.3, 0.8, 0.9);
}
i:nth-of-type(7n) {
 opacity: 0.5;
}
i:nth-of-type(7n + 2) {
 opacity: 0.3;
}
i:nth-of-type(7n + 4) {
 opacity: 0.7;
}
i:nth-of-type(7n + 6) {
 opacity: 0.6;
 animation-timing-function: ease-in;
 transform-origin: left 10px;
}
i:nth-of-type(7n + 1) {
 opacity: 0.8;
}
.root {
 height: 580px;
 background-color: skyblue;
 border: 1px solid darkgrey;
 position: relative;
 overflow: hidden;
}
.ground,
.cloud {
 position: absolute;
 top: 0;
 right: 0;
 left: 0;
 background-repeat: no-repeat;
}
.cloud {
 width: 100%;
 height: 150px;
 background: white;
 border-radius: 0 0 90px 33% / 0 0 45px 50px;
 box-shadow:
 5px 15px 15px white,
 -5px 15px 15px white,
 0 20px 20px rgb(125 125 125 / 0.5);
 animation:
 clouds ease 5s alternate infinite 0.2s,
 wind ease-out 4s alternate infinite;
}
.ground {
 bottom: 0;
 background-image: linear-gradient(to top, white 97%, 99%, #bbbbbb 100%);
 background-position: center 580px;
 animation: snowfall linear 300s forwards;
 border: 1px solid grey;
 /* Put the ground into a 3D rendering context (because the snow flakes are in a 3d rendering context) */
 transform: translate3d(0, 0, 0);
}
@keyframes snowfall {
 from {
 background-position: center 580px;
 }
 to {
 background-position: center 280px;
 }
}
@keyframes clouds {
 from {
 border-radius: 0 0 90px 33% / 0 0 45px 50px;
 }
 to {
 border-radius: 0 0 40px 50% / 0 0 55px 80px;
 }
}
@keyframes wind {
 from {
 height: 150px;
 }
 to {
 height: 100px;
 }
}
@keyframes falling {
 from {
 transform: translate(0, -50px) rotate(0deg) scale(0.9, 0.9);
 }
 to {
 transform: translate(30px, 600px) rotate(360deg) scale(1.1, 1.1);
 }
}
/* By default, the animations are paused. */
i,
div[class] {
 animation-play-state: paused;
}
/* When the div is hovered, the animation plays. Also,
when the input is checked, the animation coming after the checked checkbox plays */
div:hover *,
input:checked ~ div * {
 animation-play-state: running;
}
/* Change the content of the label that comes right after the input. Included aria-label on the label to improve accessibility. */
input + label::before {
 content: "Play ";
}
input:checked + label::before {
 content: "Pause ";
}

Diese Beispielanimation verwendet animation-iteration-count, um die Flocken wiederholt fallen zu lassen, animation-direction, um die Wolke hin und her zu bewegen, animation-fill-mode, um den Schneepegel als Reaktion auf die Wolkenbewegung zu erhöhen, und animation-play-state, um die Animation zu pausieren.

Klicken Sie im obigen Beispiel auf "Abspielen", um den Code für die Animation im MDN Playground anzusehen oder zu bearbeiten.

Referenz

Eigenschaften

Das CSS-Animationsmodul Level 2 führt auch die animation-trigger, animation-trigger-exit-range, animation-trigger-exit-range-end, animation-trigger-exit-range-start, animation-trigger-range, animation-trigger-range-end, animation-trigger-range-start, animation-trigger-timeline, und animation-trigger-type Eigenschaften ein. Derzeit unterstützen keine Browser diese Funktionen.

At-Rules und Deskriptoren

Ereignisse

Alle Animationen, selbst solche mit einer Dauer von 0 Sekunden, werfen Animationsevents aus.

Schnittstellen

Leitfäden

Verwendung von CSS-Animationen

Schritt-für-Schritt-Anleitung zum Erstellen von Animationen mit CSS. Dieser Artikel beschreibt die animationsbezogenen CSS-Eigenschaften und, wie sie zusammen mit at-rule interagieren.

Animierbare CSS-Eigenschaften

Überblick darüber, wie verschiedene CSS-Eigenschaften animiert werden können, einschließlich ihrer Animationstypen und Interpolationsmethoden.

Verwendung der Web Animations API

Häufige Animationsanforderungen, die mit wenigen Zeilen JavaScript gelöst werden können.

Verwandte Konzepte

Spezifikationen

Spezifikation
CSS Animations Level 2
CSS Animations Level 1

Siehe auch

Help improve MDN

Erfahren Sie, wie Sie beitragen können Diese Seite wurde automatisch aus dem Englischen übersetzt.

AltStyle によって変換されたページ (->オリジナル) /