CSS实现菜单按钮动画
要写一个下拉菜单点击按钮 菜单入口就是是点击一个图标按钮 之前都是随便用个图片代替 今天突然想用CSS写个效果 主要参考澎湃移动端右上角的按钮
- 效果:

- HTML
//vue 中通过点击事件改变class
<div
class="burger"
style="float: right;"
:class="{'transform':rightTopBtn}"
@click.stop="rightTopBtn=!rightTopBtn"
>
<div></div>
<div></div>
<div></div>
</div>- CSS
<!--按钮容器 START-->
.burger {
cursor: pointer;
display: inline-block;
margin: 7px 6px 0 0;
outline: none;
}
<!--按钮容器 END-->
<!--三条横线 通过rotate3d实现旋转 START-->
.burger div {
width: 30px;
height: 4px;
margin-bottom: 6px;
background-color: rgb(51, 51, 51);
transform: rotate3d(0, 0, 0, 0);
}
<!--三条横线 END-->
.burger.transform div {
background-color: transparent;
}
.burger.transform div:first-of-type {
top: 10px;
transform: rotate3d(0, 0, 1, 45deg)
}
.burger.transform div:last-of-type {
bottom: 10px;
transform: rotate3d(0, 0, 1, -45deg)
}
<!--点击后第一个和第三个横线的效果 START-->
.burger.transform div:first-of-type, .burger.transform div:last-of-type {
transition: transform .4s .3s ease, background-color 250ms ease-in;
background: #00c1de;
}
<!--点击后第一个和第三个横线的效果 END-->
<!--取消点击后恢复动画 START-->
.burger div:first-of-type, .burger div:last-of-type {
transition: transform .3s ease .0s, background-color 0ms ease-out;
position: relative;
}
<!--取消点击后恢复动画 END-->- 只用transition也是能达到 animation的效果的 通过设置不同属性的变化 掌握好变化时间 和延时的时间 就可以让动画有先后顺序
相关推荐
Ladyseven 2020-10-22
mapaler 2020-07-17
云端漂移 2020-07-17
淡风wisdon大大 2020-06-27
lanzhusiyu 2020-06-21
AlisaClass 2020-06-05
jiedinghui 2020-06-04
usepython 2020-05-31
flycony 2020-05-30
88284453 2020-05-09
hqulyc 2020-05-05
yaodilu 2020-04-30
冰蝶 2020-04-20
vavid 2020-04-20
AlisaClass 2020-04-11
ELEMENTS爱乐小超 2020-04-07
lcyangcss 2020-03-28