这篇文章将为大家详细讲解有关怎么用纯CSS实现类似于旗帜飘扬动画效果,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。
成都创新互联成立于2013年,我们提供高端网站建设、成都网站制作、成都网站设计公司、网站定制、成都全网营销推广、小程序设计、微信公众号开发、seo优化排名服务,提供专业营销思路、内容策划、视觉设计、程序开发来完成项目落地,为VR全景企业提供源源不断的流量和订单咨询。
代码解读
定义dom,容器中包含15个元素:
居中显示:
body{
margin:0;
height:100vh;
display:flex;
align-items:center;
justify-content:center;
background-color:black;
}
定义容器尺寸:
.flag{
width:10em;
height:15em;
font-size:20px;
}
设置线条样式:
.flagspan{
width:0.25em;
height:inherit;
background-color:deepskyblue;
}
让线条平铺:
.flag{
display:flex;
justify-content:space-between;
}
增加3d透视效果:
.flag{
transform:perspective(500px)rotateY(-20deg);
}
定义左右移动的动画效果:
.flagspan{
animation:wave1.5sease-in-outinfinitealternate;
}
@keyframeswave{
to{
transform:translateX(2em);
}
}
设置元素变量值:
.flagspan:nth-child(1){
--n:1;
}
.flagspan:nth-child(2){
--n:2;
}
/*共15个元素,每元素的--n变量值等于它的序号。*/
/*中间代码略……*/
.flagspan:nth-child(14){
--n:14;
}
.flagspan:nth-child(15){
--n:15;
}
让各线条分别延时启动动画,形成旗帜飘扬的效果:
.flagspan{
animation-delay:calc(var(--n)*-0.1s);
}
最后,增加光影效果:
.flagspan{
background-color:ghostwhite;
}
@keyframeswave{
to{
transform:translateX(2em);
background-color:deepskyblue;
}
}
关于“怎么用纯CSS实现类似于旗帜飘扬动画效果”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,使各位可以学到更多知识,如果觉得文章不错,请把它分享出去让更多的人看到。
售后响应及时
7×24小时客服热线数据备份
更安全、更高效、更稳定价格公道精准
项目经理精准报价不弄虚作假合作无风险
重合同讲信誉,无效全额退款