Maison > interface Web > tutoriel CSS > Comment utiliser CSS pour réaliser l'effet d'animation du chargeur de montagnes russes

Comment utiliser CSS pour réaliser l'effet d'animation du chargeur de montagnes russes

不言
Libérer: 2018-08-08 14:52:12
original
2037 Les gens l'ont consulté

Le contenu de cet article explique comment utiliser CSS pour réaliser l'effet d'animation du chargeur de montagnes russes. Il a une certaine valeur de référence. Les amis dans le besoin peuvent s'y référer.

Aperçu de l'effet

Comment utiliser CSS pour réaliser leffet danimation du chargeur de montagnes russes

Interprétation du code

Définir dom, conteneur Contient 3 éléments, représentant 3 points :

<p>
    <span></span>
    <span></span>
    <span></span>
</p>
Copier après la connexion

Affichage centré :

body {
    margin: 0;
    height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(to right, silver, teal);
}
Copier après la connexion

Définit le diamètre de la grande roue, et les autres longueurs utilisent cette valeur comme échelle de base :

.loader {
    --diameter: 10em;
}
Copier après la connexion

Définissez la taille du conteneur, la largeur est 2 fois la hauteur :

.loader {
    --width: calc(var(--diameter) * 2);
    width: var(--width);
    height: var(--diameter);
}
Copier après la connexion

Définissez les attributs partagés du pseudo-élément :

.loader {
    position: relative;
}

.loader::before,
.loader::after {
    content: '';
    position: absolute;
    bottom: 0;
}
Copier après la connexion

Dessinez le piste du bas, En même temps, une variable représentant l'épaisseur du trait est définie :

.loader {
    --stroke-width: calc(var(--diameter) / 40);
    color: white;
}

.loader::before {
    width: inherit;
    height: var(--stroke-width);
    background-color: currentColor;
}
Copier après la connexion

Dessinez l'orbite circulaire au milieu :

.loader::after {
    box-sizing: border-box;
    width: var(--diameter);
    height: var(--diameter);
    border: var(--stroke-width) solid;
    border-radius: 50%;
    left: 25%;
}
Copier après la connexion

Dessinez un point, et définissez également une variable représentant le diamètre du point Variables :

.loader {
    --dot-diameter: calc(var(--diameter) / 10);
}

.loader span {
    position: absolute;
    width: var(--dot-diameter);
    height: var(--dot-diameter);
    background-color: currentColor;
    border-radius: 50%;
    bottom: var(--stroke-width);
    left: calc((var(--width) - var(--dot-diameter)) / 2);
}
Copier après la connexion

Ajoutez un effet d'animation pour que les points tournent le long d'une orbite circulaire :

.loader span {
    animation:
        rotating 2s linear infinite;
    --vertical-center: calc((var(--diameter) / 2 - var(--stroke-width) - var(--dot-diameter)) * -1);
    transform-origin: 50% var(--vertical-center);
}

@keyframes rotating {
    0%, 10% {
        transform: rotate(0deg);
    }

    60%, 100% {
        transform: rotate(-1turn);
    }
}
Copier après la connexion

Ajoutez un effet d'animation pour le points à déplacer :

.loader span {
    animation:
        run 2s linear infinite,
        rotating 2s linear infinite;
}

@keyframes run {
    0% {
        left: calc(var(--dot-diameter) * -1);
    }

    10%, 60% {
        left: calc((var(--width) - var(--dot-diameter)) / 2);
    }

    70%, 100% {
        left: calc(var(--width));
    }
}
Copier après la connexion

Définissez un délai d'animation pour les 2 autres points afin que les 3 points ressemblent à 3 chariots côte à côte :

.loader span:nth-child(1) {
    animation-delay: 0.075s;
}

.loader span:nth-child(2) {
    animation-delay: 0.15s;
}
Copier après la connexion

Enfin, masquez le contenu à l'extérieur du conteneur :

.loader {
    overflow: hidden;
}
Copier après la connexion

Articles connexes recommandés :

Exemples de code d'implémentation CSS du changement de navigation

Comment utiliser pure CSS pour obtenir l'effet d'un cochon vert

CSS3 réalise l'effet de bouton de menu mobile (menu)

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!

Étiquettes associées:
source:php.cn
Déclaration de ce site Web
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
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal