用CSS3做了一个求婚小动画,我脱单了!

共 2532字,需浏览 6分钟

 ·

2020-12-17 13:54

点击关注选择“置顶或者星标”

你的关注意义重大!

作者:leap_frog

https://segmentfault.com/a/1190000009798046


首先放张效果图

然后一步步分析一下:

首先是刚出现的新郎的动画

.w-m img{
    margin-right0;
    float: right;
    margin-top60px;
    animation: toWoman 0.5s ease .5s both;
}
@keyframes toWoman{
    0%{
        opacity0;
        transformtranslate(-200px);
    }
    100%{
        opacity1;
        transformtranslate(0);
    }
}

里面用到的知识点:

  • animation:是一个简写属性,用于设置六个动画属性

    • animation-name 规定需要绑定到选择器的 keyframe 名称

    • animation-duration 规定完成动画所花费的时间,以秒或毫秒计

    • animation-timing-function 规定动画的速度曲线

    • animation-delay 规定在动画开始之前的延迟

    • animation-iteration-count 规定动画应该播放的次数

    • animation-direction 规定是否应该轮流反向播放动画

  • keyframes:让开发者通过指定动画中特定时间点必须展现的关键帧样式(或者说停留点)来控制 CSS 动画的中间环节。这让开发者能够控制动画中的更多细节而不是全部让浏览器自动处理

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

然后是那朵花的 css

.w-f{
    position: absolute;
    z-index20;
    left50%;
    margin-left: -30px;
    margin-top75px;
}
.w-f img{
    width60px;
    animation: show 0.4s ease 1s both;
}

@keyframes show{
    0%{
        opacity0;
        transformscale(0.1,0.1);
    }
    100%{
        opacity1;
        transformscale(1,1);
    }
}

文字部分的 css

.w-t-m{
    position: absolute;
    left50%;
    z-index10;
    line-height80px;
    color#ff720a;
    letter-spacing5px;
    opacity0;
    animation: titleBloom 1s linear 1s both;
    font-size26px;
    margin-left: -125px;
}
@keyframes titleBloom{
    0% {
        transformtranslate(-50px);
    }
    100% {
        opacity1;
        transformtranslate(0);
    }
}

文字边烟花的效果

.w-t img{
    opacity0;
    animation: bloom 2s ease 1.2s infinite;
}
.w-t img.boom2{
    float: right;
    animation: bloom 2s ease 1.5s infinite;
}
.w-t img.boom3{
    position: absolute;
    margin-top40px;
    animation: bloom 2s ease 1.4s infinite;
}
@keyframes bloom{
    0% {
        transformscale(0,0);
    }
    100% {
        opacity1;
        transformscale(1,1);
    }
}

最后几束花的效果

.w-fls{
    width820px;
    margin0 auto;
}
.w-fls img{
    height120px;
    z-index400;
    animation: showFlows 0.4s ease 2.3s both;
}
@keyframes showFlows{
    0%{
        opacity0;
        transformtranslate(0,200px);
    }
    100%{
        opacity1;
        transformtranslate(0);
    }
}
.w-2{
    margin-top: -130px;
    padding-left100px;
}
.w-2 img{
    animation: showFlows 0.4s ease 2.7s both;
}

写到这里,觉得前端开发原来是这么有趣的一件事哈~

源码:

https://github.com/sunweiling/wedding

—————END—————



喜欢本文的朋友,欢迎关注公众号 程序员哆啦A梦,收看更多精彩内容

点个[在看],是对小达最大的支持!


如果觉得这篇文章还不错,来个【分享、点赞、在看】三连吧,让更多的人也看到~

浏览 47
点赞
评论
收藏
分享

手机扫一扫分享

分享
举报
评论
图片
表情
推荐
点赞
评论
收藏
分享

手机扫一扫分享

分享
举报