Heim > Web-Frontend > CSS-Tutorial > Warum funktionieren CSS3-Übergänge nicht, wenn die Anzeige auf „Keine' eingestellt ist?

Warum funktionieren CSS3-Übergänge nicht, wenn die Anzeige auf „Keine' eingestellt ist?

Mary-Kate Olsen
Freigeben: 2024-11-08 08:19:01
Original
991 Leute haben es durchsucht

Why Do CSS3 Transitions Not Work When Display Is Set To None?

CSS3-Übergänge funktionieren nicht mit der Anzeigeeigenschaft

In CSS spielt die Anzeigeeigenschaft eine entscheidende Rolle bei der Definition, ob ein Element sichtbar oder ausgeblendet ist . Übergänge hingegen ermöglichen sanfte visuelle Veränderungen im Laufe der Zeit. Der Versuch, Übergänge auf Elemente anzuwenden, deren Anzeige auf „Keine“ eingestellt ist, kann jedoch zu unerwartetem Verhalten führen.

Lösung des Problems

Das Problem ergibt sich aus der Art der Anzeige Eigentum. Wenn die Anzeige eines Elements auf „Keine“ gesetzt ist, wird es von der Seite entfernt, als ob es nie dort gewesen wäre. Daher kann es nicht teilweise angezeigt werden oder Übergänge durchlaufen.

Alternative Lösung: Verwendung von Deckkraft

Um den gewünschten Fading-Effekt beim Schweben zu erzielen, sollten Sie stattdessen die Deckkrafteigenschaft verwenden . Die Deckkraft steuert die Transparenz eines Elements und ermöglicht dessen allmähliches Erscheinen oder Verschwinden.

CSS-Lösung

Implementieren Sie die folgenden CSS-Anpassungen, um den Fading-Effekt zu aktivieren:

#header #button:hover > .content {
    opacity: 1;
    height: 150px;
    padding: 8px;
}

#header #button .content {
    opacity: 0;
    height: 0;
    padding: 0 8px;
    overflow: hidden;
    transition: all .3s ease .15s;
}
Nach dem Login kopieren

Durch die Kombination von Deckkraft und Übergang wird der verborgene Inhalt eingeblendet, wenn Sie mit der Maus über die Schaltfläche fahren. Herstellerpräfixe für browserübergreifende Kompatibilität wurden der Kürze halber weggelassen.

Andere Überlegungen

Neben der Deckkraft könnte man auch die Anpassung der Höhe und der Fülleigenschaften in Betracht ziehen, um ähnliches zu erreichen Effekte.

Zusätzlich Ressourcen

  • [CSS-Übergangs-Tutorial](https://www.w3schools.com/css/css3_transitions.asp)
  • [Umgang mit versteckten Elementen mit CSS Übergänge](https://css-tricks.com/transitions-with-hidden-elements/)
  • [Ähnliches Thema zum Stapelüberlauf](https://stackoverflow.com/questions/30130725/css- Animation-not-visible-when-display-none)

Das obige ist der detaillierte Inhalt vonWarum funktionieren CSS3-Übergänge nicht, wenn die Anzeige auf „Keine' eingestellt ist?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Neueste Artikel des Autors
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage