recherche

Maison  >  Questions et réponses  >  le corps du texte

javascript - animation de transition automatique de hauteur de transition

1.Pourquoi n'y a-t-il pas d'effet d'animation lors du rétrécissement ?

2.Code

<!DOCTYPE html>
<html lang="en">

<head>
    <title></title>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1">
    <style>
        * {
            transition: all .6s;
        }

        .container {
            position: fixed;
            top: 0;
            left: 0;
            right: 0;
            height: 100px;
            max-height: 100px;
            width: 100px;
            margin: 5px auto;
            background: RGBA(0, 43, 54, 0.80);
            overflow: hidden;
            text-align: center;
        }

        .container:hover {
            height: auto;
            max-height: 100%;
            bottom: 0px;
        }
    </style>
</head>

<body>
    <p class="sketch">
        <p class="container">
            <!--<a id="switch" href="javascript:void(0)">开关</a>-->
        </p>
    </p>
    <!--<script>
        const classList = document.querySelector('.container').classList;
        document.querySelector('#switch').addEventListener('click', function (e) {
            if (classList.contains('expand')) {
                document.querySelector('.container').classList.remove('expand');
            } else {
                document.querySelector('.container').classList.add('expand');
            }
        });
    </script>-->
</body>

</html>

3. Démo en ligne (résolu)

大家讲道理大家讲道理2857 Il y a quelques jours873

répondre à tous(3)je répondrai

  • ringa_lee

    ringa_lee2017-05-16 13:23:31

    Parce que l'animation de transition que nous pouvons voir est en fait le processus de changement de la valeur height, et que vous n'avez pas attribué de valeur claire à height dans l'attribut hover, donc après avoir déplacé la souris, le navigateur en fait je Je ne sais pas de quelle valeur passer à la valeur initiale, donc je reviens directement à la valeur initiale, donc il n'y a pas d'effet de transition

    répondre
    0
  • 怪我咯

    怪我咯2017-05-16 13:23:31

    La raison est celle mentionnée au 1er étage. Peut être réglé height:100%;.

    répondre
    0
  • 伊谢尔伦

    伊谢尔伦2017-05-16 13:23:31

    .container:hover {
        height: 100%; // 这个要明确值
        max-height: 100%;
        bottom: 0px;
    }

    répondre
    0
  • Annulerrépondre