用CSS3实现倒计时

实现效果:

在这里插入图片描述
代码如下:

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

<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
<style>
    .digit {
        display: inline-block;
        font-size: 200px;
        color: rgba(0, 0, 0, 0.25);
        height: 180px;
        line-height: 1;
    }

    .time-part-wrapper {
        display: inline-block;
        margin-right: 50px;
        position: relative;
    }

    .time-part-wrapper:not(:last-child):after {
        content: ":";
        display: block;
        width: 30px;
        height: 230px;
        position: absolute;
        top: 0px;
        right: -30px;
        color: rgba(0, 0, 0, 0.25);
        font-size: 200px;
        line-height: 0.9;
    }

    .time-part {
        width: 140px;
        text-align: center;
        height: 180px;
        overflow: hidden;
        display: inline-block;
        margin-left: -5px;
        box-sizing: border-box;
    }

    .time-part .digit-wrapper {
        animation-timing-function: cubic-bezier(1, 0, 1, 0);
    }

    .time-part.minutes.tens .digit-wrapper {
        animation-name: minutes-tens;
        animation-duration: 3600s;
        animation-iteration-count: 1;
    }

    .time-part.minutes.ones .digit-wrapper {
        animation-name: minutes-ones;
        animation-duration: 600s;
        animation-iteration-count: 6;
    }

    .time-part.seconds.tens .digit-wrapper {
        animation-name: seconds-tens;
        animation-duration: 60s;
        animation-iteration-count: 60;
    }

    .time-part.seconds.ones .digit-wrapper {
        animation-name: seconds-ones;
        animation-duration: 10s;
        animation-iteration-count: 360;
    }

    .time-part.hundredths.tens .digit-wrapper {
        animation-name: hundredths-tens;
        animation-duration: 1s;
        animation-iteration-count: 3600;
    }

    .time-part.hundredths.ones .digit-wrapper {
        animation-name: hundredths-ones;
        animation-duration: 0.1s;
        animation-iteration-count: 36000;
    }

    @keyframes minutes-tens {
        0% {
            transform: translateY(-180px);
        }

        16.66667% {
            transform: translateY(-360px);
        }

        33.33333% {
            transform: translateY(-540px);
        }

        50% {
            transform: translateY(-720px);
        }

        66.66667% {
            transform: translateY(-900px);
        }

        83.33333% {
            transform: translateY(-1080px);
        }
    }

    @keyframes minutes-ones {
        0% {
            transform: translateY(-180px);
        }

        10% {
            transform: translateY(-360px);
        }

        20% {
            transform: translateY(-540px);
        }

        30% {
            transform: translateY(-720px);
        }

        40% {
            transform: translateY(-900px);
        }

        50% {
            transform: translateY(-1080px);
        }

        60% {
            transform: translateY(-1260px);
        }

        70% {
            transform: translateY(-1440px);
        }

        80% {
            transform: translateY(-1620px);
        }

        90% {
            transform: translateY(-1800px);
        }
    }

    @keyframes seconds-tens {
        0% {
            transform: translateY(-180px);
        }

        16.66667% {
            transform: translateY(-360px);
        }

        33.33333% {
            transform: translateY(-540px);
        }

        50% {
            transform: translateY(-720px);
        }

        66.66667% {
            transform: translateY(-900px);
        }

        83.33333% {
            transform: translateY(-1080px);
        }
    }

    @keyframes seconds-ones {
        0% {
            transform: translateY(-180px);
        }

        10% {
            transform: translateY(-360px);
        }

        20% {
            transform: translateY(-540px);
        }

        30% {
            transform: translateY(-720px);
        }

        40% {
            transform: translateY(-900px);
        }

        50% {
            transform: translateY(-1080px);
        }

        60% {
            transform: translateY(-1260px);
        }

        70% {
            transform: translateY(-1440px);
        }

        80% {
            transform: translateY(-1620px);
        }

        90% {
            transform: translateY(-1800px);
        }
    }

    @keyframes hundredths-tens {
        0% {
            transform: translateY(-180px);
        }

        10% {
            transform: translateY(-360px);
        }

        20% {
            transform: translateY(-540px);
        }

        30% {
            transform: translateY(-720px);
        }

        40% {
            transform: translateY(-900px);
        }

        50% {
            transform: translateY(-1080px);
        }

        60% {
            transform: translateY(-1260px);
        }

        70% {
            transform: translateY(-1440px);
        }

        80% {
            transform: translateY(-1620px);
        }

        90% {
            transform: translateY(-1800px);
        }
    }

    @keyframes hundredths-ones {
        0% {
            transform: translateY(-180px);
        }

        10% {
            transform: translateY(-360px);
        }

        20% {
            transform: translateY(-540px);
        }

        30% {
            transform: translateY(-720px);
        }

        40% {
            transform: translateY(-900px);
        }

        50% {
            transform: translateY(-1080px);
        }

        60% {
            transform: translateY(-1260px);
        }

        70% {
            transform: translateY(-1440px);
        }

        80% {
            transform: translateY(-1620px);
        }

        90% {
            transform: translateY(-1800px);
        }
    }

    body {
        background: #F1614B;
        margin: 0;
        font-family: "Aldrich";
    }

    .wrapper {
        margin: 100px auto;
        width: 1000px;
        position: relative;
    }

    .wrapper:before,
    .wrapper:after {
        content: "";
        display: block;
        position: absolute;
        width: 100%;
        left: 0;
        height: 20px;
        z-index: 10;
    }

    .wrapper:before {
        top: 0px;
        background-image: url('data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0idXRmLTgiPz4gPHN2ZyB2ZXJzaW9uPSIxLjEiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyI+PGRlZnM+PGxpbmVhckdyYWRpZW50IGlkPSJncmFkIiBncmFkaWVudFVuaXRzPSJvYmplY3RCb3VuZGluZ0JveCIgeDE9IjAuNSIgeTE9IjAuMCIgeDI9IjAuNSIgeTI9IjEuMCI+PHN0b3Agb2Zmc2V0PSIwJSIgc3RvcC1jb2xvcj0iI2YxNjE0YiIvPjxzdG9wIG9mZnNldD0iMTAwJSIgc3RvcC1jb2xvcj0iI2YxNjE0YiIgc3RvcC1vcGFjaXR5PSIwLjAiLz48L2xpbmVhckdyYWRpZW50PjwvZGVmcz48cmVjdCB4PSIwIiB5PSIwIiB3aWR0aD0iMTAwJSIgaGVpZ2h0PSIxMDAlIiBmaWxsPSJ1cmwoI2dyYWQpIiAvPjwvc3ZnPiA=');
        background-size: 100%;
        background-image: -webkit-gradient(linear, 50% 0%, 50% 100%, color-stop(0%, #f1614b), color-stop(100%, rgba(241, 97, 75, 0)));
        background-image: -moz-linear-gradient(top, #f1614b 0%, rgba(241, 97, 75, 0) 100%);
        background-image: -webkit-linear-gradient(top, #f1614b 0%, rgba(241, 97, 75, 0) 100%);
        background-image: linear-gradient(to bottom, #f1614b 0%, rgba(241, 97, 75, 0) 100%);
    }

    .wrapper:after {
        bottom: 0px;
        background-image: url('data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0idXRmLTgiPz4gPHN2ZyB2ZXJzaW9uPSIxLjEiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyI+PGRlZnM+PGxpbmVhckdyYWRpZW50IGlkPSJncmFkIiBncmFkaWVudFVuaXRzPSJvYmplY3RCb3VuZGluZ0JveCIgeDE9IjAuNSIgeTE9IjAuMCIgeDI9IjAuNSIgeTI9IjEuMCI+PHN0b3Agb2Zmc2V0PSIwJSIgc3RvcC1jb2xvcj0iI2YxNjE0YiIgc3RvcC1vcGFjaXR5PSIwLjAiLz48c3RvcCBvZmZzZXQ9IjEwMCUiIHN0b3AtY29sb3I9IiNmMTYxNGIiLz48L2xpbmVhckdyYWRpZW50PjwvZGVmcz48cmVjdCB4PSIwIiB5PSIwIiB3aWR0aD0iMTAwJSIgaGVpZ2h0PSIxMDAlIiBmaWxsPSJ1cmwoI2dyYWQpIiAvPjwvc3ZnPiA=');
        background-size: 100%;
        background-image: -webkit-gradient(linear, 50% 0%, 50% 100%, color-stop(0%, rgba(241, 97, 75, 0)), color-stop(100%, #f1614b));
        background-image: -moz-linear-gradient(top, rgba(241, 97, 75, 0) 0%, #f1614b 100%);
        background-image: -webkit-linear-gradient(top, rgba(241, 97, 75, 0) 0%, #f1614b 100%);
        background-image: linear-gradient(to bottom, rgba(241, 97, 75, 0) 0%, #f1614b 100%);
    }
</style>
</head>

<body>
<div class='wrapper'>
    <div class='time-part-wrapper'>
        <div class='time-part minutes tens'>
            <div class='digit-wrapper'>
                <span class='digit'>0</span>
                <span class='digit'>5</span>
                <span class='digit'>4</span>
                <span class='digit'>3</span>
                <span class='digit'>2</span>
                <span class='digit'>1</span>
                <span class='digit'>0</span>
            </div>
        </div>
        <div class='time-part minutes ones'>
            <div class='digit-wrapper'>
                <span class='digit'>0</span>
                <span class='digit'>9</span>
                <span class='digit'>8</span>
                <span class='digit'>7</span>
                <span class='digit'>6</span>
                <span class='digit'>5</span>
                <span class='digit'>4</span>
                <span class='digit'>3</span>
                <span class='digit'>2</span>
                <span class='digit'>1</span>
                <span class='digit'>0</span>
            </div>
        </div>
    </div>
    <div class='time-part-wrapper'>
        <div class='time-part seconds tens'>
            <div class='digit-wrapper'>
                <span class='digit'>0</span>
                <span class='digit'>5</span>
                <span class='digit'>4</span>
                <span class='digit'>3</span>
                <span class='digit'>2</span>
                <span class='digit'>1</span>
                <span class='digit'>0</span>
            </div>
        </div>
        <div class='time-part seconds ones'>
            <div class='digit-wrapper'>
                <span class='digit'>0</span>
                <span class='digit'>9</span>
                <span class='digit'>8</span>
                <span class='digit'>7</span>
                <span class='digit'>6</span>
                <span class='digit'>5</span>
                <span class='digit'>4</span>
                <span class='digit'>3</span>
                <span class='digit'>2</span>
                <span class='digit'>1</span>
                <span class='digit'>0</span>
            </div>
        </div>
    </div>
    <div class='time-part-wrapper'>
        <div class='time-part hundredths tens'>
            <div class='digit-wrapper'>
                <span class='digit'>0</span>
                <span class='digit'>9</span>
                <span class='digit'>8</span>
                <span class='digit'>7</span>
                <span class='digit'>6</span>
                <span class='digit'>5</span>
                <span class='digit'>4</span>
                <span class='digit'>3</span>
                <span class='digit'>2</span>
                <span class='digit'>1</span>
                <span class='digit'>0</span>
            </div>
        </div>
        <div class='time-part hundredths ones'>
            <div class='digit-wrapper'>
                <span class='digit'>0</span>
                <span class='digit'>9</span>
                <span class='digit'>8</span>
                <span class='digit'>7</span>
                <span class='digit'>6</span>
                <span class='digit'>5</span>
                <span class='digit'>4</span>
                <span class='digit'>3</span>
                <span class='digit'>2</span>
                <span class='digit'>1</span>
                <span class='digit'>0</span>
            </div>
        </div>
    </div>
</div>
</body>

</html>

猜你喜欢

转载自blog.csdn.net/weixin_52630329/article/details/113151252
今日推荐