为了账号安全,请及时绑定邮箱和手机立即绑定

css3 transform与animation妙用

标签:
CSS3

transtion与animation为css3新增的属性,主要用来实现一些动画效果

transtion属性向元素应用2D或3D转换,允许我们对元素进行旋转、缩放、移动或倾斜

https://img1.sycdn.imooc.com//5ba0a6860001a36711570700.jpg

animation动画有三个基本要素:

1、告诉系统需要执行哪个动画。

2、自己创建一个所需的动画

3、告诉系统需要执行动画的时长

https://img1.sycdn.imooc.com//5ba0ad860001f28016660575.jpg

例子:纯CSS3波浪加载效果

https://img1.sycdn.imooc.com//5ba0af1f0001b0ff05720482.jpg

以下为效果代码

   <title>纯CSS3波浪加载效果</title>
    <style>
        *{
            margin: 0;
            padding: 0;
        }
        .show{
            position: absolute;
            top: 50%;
            left: 50%;
            margin-top: -100px;
            margin-left: -100px;
            width: 200px;
            height: 200px;
            border-radius: 50%;
            background-color: #38ADFF;
            overflow: hidden;
            z-index: 100;
        }
        .water{
            position: absolute;
            left: 50%;
            bottom: 50%;
            margin-left: -300px;
            width: 600px;
            height: 600px;
            background-color: white;
            border-radius: 45%;
            transform: rotate(0deg);
            animation: roate1 10s infinite;
            z-index: -1;
        }
        .water:nth-of-type(2){
            bottom: 48%;
            animation: roate1 9s infinite;
            background-color: rgba(255,255,255,0.8);
        }
        .centent{
            position: absolute;
            width: 200px;
            height: 200px;
            border-radius: 50%;
            border: 1px solid #3F4657;
            box-sizing: border-box;
        }
        .centent>p{
            line-height: 200px;
            text-align: center;
        }
        @keyframes roate1 {
            50%{
                transform:rotate(180deg);
            }100%{
                transform:rotate(360deg);
                         }
        }
    </style>
</head>
<body>
<div class="show">
    <div class="water"></div>
    <div class="water"></div>
    <div class="centent">
        <p>50%</p>
    </div>
</div>
</body>

思路分析,我们要实现一个有波浪的加载效果,首先需要制作曲线,再让曲线以波浪的形式滚动起来。曲线可以通过canvas制作,但是那样相对较复杂,在这里我们通过border-radius的方式取巧制作。

https://img1.sycdn.imooc.com//5ba0b50d000123cb09380502.jpg

但是得到的类圆形的曲线,如图黄色内部的曲线才是我们想要的

https://img1.sycdn.imooc.com//5ba0b777000179a107580498.jpg

在得到波浪后,将放大的类圆形背景色改为与白色。再新建一个同样的类圆形,通过使用rgba的方式,设置一定的透明的可以形成第二层的远处波浪,增加真实感。

https://img1.sycdn.imooc.com//5ba0b94100019ada06490451.jpg

再来只要添加一层用来显示加载进度的div就可以了

https://img1.sycdn.imooc.com//5ba0baa00001f02a19200892.jpg



点击查看更多内容
2人点赞

若觉得本文不错,就分享一下吧!

评论

作者其他优质文章

正在加载中
Web前端工程师
手记
粉丝
76
获赞与收藏
534

关注作者,订阅最新文章

阅读免费教程

感谢您的支持,我会继续努力的~
扫码打赏,你说多少就多少
赞赏金额会直接到老师账户
支付方式
打开微信扫一扫,即可进行扫码打赏哦
今天注册有机会得

100积分直接送

付费专栏免费学

大额优惠券免费领

立即参与 放弃机会
意见反馈 帮助中心 APP下载
官方微信

举报

0/150
提交
取消