CSS实现菜单按钮动画的代码示例
发布时间:09/01 来源:未知 浏览:
关键词:
要写一个下拉菜单点击按钮 菜单入口就是是点击一个图标按钮 此前都是随意用个图片代替 今天忽然想用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 p { width: 30px; height: 4px; margin-bottom: 6px; background-color: rgb(51, 51, 51); transform: rotate3d(0, 0, 0, 0); } <!--三条横线 END--> .burger.transform p { background-color: transparent; } .burger.transform p:first-of-type { top: 10px; transform: rotate3d(0, 0, 1, 45deg) } .burger.transform p:last-of-type { bottom: 10px; transform: rotate3d(0, 0, 1, -45deg) } <!--点击后第一个和第三个横线的结果 START--> .burger.transform p:first-of-type, .burger.transform p:last-of-type { transition: transform .4s .3s ease, background-color 250ms ease-in; background: #00c1de; } <!--点击后第一个和第三个横线的结果 END--> <!--取消点击后复原动画 START--> .burger p:first-of-type, .burger p:last-of-type { transition: transform .3s ease .0s, background-color 0ms ease-out; position: relative; } <!--取消点击后复原动画 END-->
只用transition也是能到达 animation的结果的 通过设定不一样属性的转变 把握好转变时间 和延时的时间 就可以让动画有前后次序
以上就是CSS实现菜单按钮动画的代码示例的具体内容,更多请关注百分百源码网其它相关文章!