Maison >interface Web >tutoriel CSS >Comment puis-je créer des transitions CSS fluides lors de la modification de l'affichage et de l'opacité ?

Comment puis-je créer des transitions CSS fluides lors de la modification de l'affichage et de l'opacité ?

Susan Sarandon
Susan Sarandonoriginal
2024-10-30 04:57:03317parcourir

How can I create smooth CSS transitions when changing both display and opacity?

Création de transitions CSS fluides avec des changements d'affichage et d'opacité

Dans le monde du développement Web, la création d'interfaces utilisateur visuellement attrayantes et interactives est essentielle. Les animations CSS jouent un rôle essentiel pour y parvenir, nous permettant d'effectuer une transition transparente entre les différents états d'un élément.

Lorsque vous travaillez avec des animations CSS3, il n'est pas rare de rencontrer des situations dans lesquelles vous devez faire la transition entre plusieurs propriétés, telles que opacité et affichage. Cependant, la combinaison de ces propriétés peut être délicate, car la transition directe de la propriété display peut entraîner des changements brusques.

Considérez le code CSS suivant :

.child {
    opacity: 0;
    display: none;

    -webkit-transition: opacity 0.5s ease-in-out;
    -moz-transition: opacity 0.5s ease-in-out;
    transition: opacity 0.5s ease-in-out;
}

.parent:hover .child {
    opacity: 0.9;
    display: block;
}

Ce code vise à faire apparaître un élément avec la classe « enfant » en survol. Cependant, cela ne fonctionne pas correctement car la transition directe de la propriété d'affichage de « aucun » à « bloquer » crée une apparence abrupte.

Pour résoudre ce problème, nous pouvons exploiter les images clés CSS pour obtenir une transition en douceur entre les deux Etats. Le code suivant illustre cette approche :

.parent:hover .child
{
    display: block;

    -webkit-animation: fadeInFromNone 0.5s ease-out;
    -moz-animation: fadeInFromNone 0.5s ease-out;
    -o-animation: fadeInFromNone 0.5s ease-out;
    animation: fadeInFromNone 0.5s ease-out;
}

@-webkit-keyframes fadeInFromNone {
    0% {
        display: none;
        opacity: 0;
    }

    1% {
        display: block;
        opacity: 0;
    }

    100% {
        display: block;
        opacity: 1;
    }
}

@-moz-keyframes fadeInFromNone {
    0% {
        display: none;
        opacity: 0;
    }

    1% {
        display: block;
        opacity: 0;
    }

    100% {
        display: block;
        opacity: 1;
    }
}

@-o-keyframes fadeInFromNone {
    0% {
        display: none;
        opacity: 0;
    }

    1% {
        display: block;
        opacity: 0;
    }

    100% {
        display: block;
        opacity: 1;
    }
}

@keyframes fadeInFromNone {
    0% {
        display: none;
        opacity: 0;
    }

    1% {
        display: block;
        opacity: 0;
    }

    100% {
        display: block;
        opacity: 1;
    }
}

Dans ce code, l'animation d'images clés 'fadeInFromNone' est utilisée pour faire passer l'opacité de 0 à 1 tout en définissant également la propriété d'affichage sur 'block' à 1 % pour évitez l'apparition brusque.

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn