CSS怎么实现横线菜单按钮变叉号的动画效果
Admin 2022-06-29 群英技术资讯 1188 次浏览
今天小编跟大家讲解下有关“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的效果的 通过设置不同属性的变化 掌握好变化时间 和延时的时间 就可以让动画有先后顺序
总结
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
padding不能为负值,margin可以。背景色会平铺到非margin区域。marked在Flexbox或网格布局中,不存在margin-top、bottom叠加及margin-top传递现象。
在使用html进行编辑的时候,特殊符号往往会显示错误,极端情况下更可能导致网页崩溃。本文就来介绍一下如何显示特殊字符,感兴趣的可以了解一下
这篇文章主要介绍了详解flex布局中保持内容不超出容器的解决办法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
这篇文章主要介绍了移动端html5判断是否滚动到底部并且下拉加载,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
目录背景粘性定位:案例:实现的代码问题探索及项目中的坑背景最近在做项目迁移,因为技术不同,导致某些功能的问题需要手动解决;如何在居位在主体区域底部不随内容而滚动;<br /> OK进入正
成为群英会员,开启智能安全云计算之旅
立即注册关注或联系群英网络
7x24小时售前:400-678-4567
7x24小时售后:0668-2555666
24小时QQ客服
群英微信公众号
CNNIC域名投诉举报处理平台
服务电话:010-58813000
服务邮箱:service@cnnic.cn
投诉与建议:0668-2555555
Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 ICP核准(ICP备案)粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008