要寫一個下拉菜單點擊按鈕 菜單入口就是是點擊一個圖標按鈕 以前都是隨便用個圖片代替 今天忽然想用CSS寫個效果 主要參考澎湃移動端右上角的按鈕
- 效果:
-
- HTML
//vue 中經過點擊事件改變class
<div
class="burger"
style="float: right;"
:class="{'transform':rightTopBtn}"
@click.stop="rightTopBtn=!rightTopBtn"
>
<div></div>
<div></div>
<div></div>
</div>
<!--按鈕容器 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的效果的 經過設置不一樣屬性的變化 掌握好變化時間 和延時的時間 就可讓動畫有前後順序