Rumah > hujung hadapan web > tutorial css > 如何使用纯CSS实现文本的淡入动画效果(附源码)

如何使用纯CSS实现文本的淡入动画效果(附源码)

不言
Lepaskan: 2018-09-21 10:31:01
asal
4521 orang telah melayarinya

本篇文章给大家带来的内容是关于如何使用纯CSS实现文本的淡入动画效果(附源码),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。

效果预览

2100090445-5ba43e0140655_articlex.gif

源代码下载

https://github.com/comehope/front-end-daily-challenges

代码解读

定义 dom,容器中包含若干子元素,每个子元素是 1 个字母:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

<div class="container">

    <span>h</span>

    <span>a</span>

    <span>p</span>

    <span>p</span>

    <span>y</span>

    <span> </span>

    <span>h</span>

    <span>o</span>

    <span>l</span>

    <span>i</span>

    <span>d</span>

    <span>a</span>

    <span>y</span>

    <span>s</span>

</div>

Salin selepas log masuk

居中显示:

1

2

3

4

5

6

7

8

body {

    margin: 0;

    height: 100vh;

    display: flex;

    align-items: center;

    justify-content: center;

    background: linear-gradient(pink, white, pink);

}

Salin selepas log masuk

设置字体样式:

1

2

3

4

5

6

7

.container span {

    display: inline-block;

    color: purple;

    font-weight: bold;

    text-transform: uppercase;

    font-size: 40px;

}

Salin selepas log masuk

定义文字从左到右的移动效果:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

.container span {

    animation: sideSlide 4s forwards infinite;

    transform: translateX(-100vw);

}

 

@keyframes sideSlide {

    15%, 20% {

        transform: translateX(0.5em);

    }

 

    24% {

        transform: translateX(0);

    }

 

    25%, 75% {

        transform: translateX(0);

    }

 

    90%, 100% {

        transform: translateX(100vw);

    }

}

Salin selepas log masuk

增加文字缩放的动画效果:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

.container span {

    transform: translateX(-100vw) scale(0);

}

 

@keyframes sideSlide {

    15%, 20% {

        transform: translateX(0.5em) scale(1);

    }

 

    24% {

        transform: translateX(0) scale(1.2);

    }

 

    25%, 75% {

        transform: translateX(0) scale(1);

    }

 

    90%, 100% {

        transform: translateX(100vw) scale(0);

    }

}

Salin selepas log masuk

增加文字入场和出场时的淡入淡出效果:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

.container span {

    filter: opacity(0);

}

 

@keyframes sideSlide {

    15%, 20% {

        transform: translateX(0.5em) scale(1);

    }

 

    24% {

        transform: translateX(0) scale(1.2);

    }

 

    25%, 75% {

        transform: translateX(0) scale(1);

        filter: opacity(1);

    }

 

    90%, 100% {

        transform: translateX(100vw) scale(0);

        filter: opacity(0);

    }

}

Salin selepas log masuk

增加文字变色的效果:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

@keyframes sideSlide {

    15%, 20% {

        transform: translateX(0.5em) scale(1);

        color: purple;

    }

 

    24% {

        transform: translateX(0) scale(1.2);

        color: cyan;

    }

 

    25%, 75% {

        transform: translateX(0) scale(1);

        filter: opacity(1);

        color: purple;

    }

 

    90%, 100% {

        transform: translateX(100vw) scale(0);

        filter: opacity(0);

    }

}

Salin selepas log masuk

设置子元素的下标变量:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

.container span:nth-child(1) { --n: 1; }

.container span:nth-child(2) { --n: 2; }

.container span:nth-child(3) { --n: 3; }

.container span:nth-child(4) { --n: 4; }

.container span:nth-child(5) { --n: 5; }

.container span:nth-child(6) { --n: 6; }

.container span:nth-child(7) { --n: 7; }

.container span:nth-child(8) { --n: 8; }

.container span:nth-child(9) { --n: 9; }

.container span:nth-child(10) { --n: 10; }

.container span:nth-child(11) { --n: 11; }

.container span:nth-child(12) { --n: 12; }

.container span:nth-child(13) { --n: 13; }

.container span:nth-child(14) { --n: 14; }

Salin selepas log masuk

设置子元素的动画延时:

1

2

3

.container span {

    animation-delay: calc((var(--n) - 1) * 0.05s);

}

Salin selepas log masuk

大功告成!

Atas ialah kandungan terperinci 如何使用纯CSS实现文本的淡入动画效果(附源码). Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Label berkaitan:
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Artikel terbaru oleh pengarang
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan