使用transform和@keyframes实现滑动面板动画,通过translateX控制位移,结合ease缓动和forwards保持状态,优先用transform提升性能,避免重排,并可通过JavaScript控制类名切换动画。
在CSS中实现滑动面板动画,可以通过 transform 属性结合 @keyframes 关键帧来完成。这种方式性能好、代码简洁,且能实现流畅的过渡效果。
transform: translateX() 可以让元素在水平方向移动,配合 @keyframes 定义动画过程,实现从左或右滑入的面板效果。
示例:从左侧滑入的面板
.slide-panel {
width: 300px;
height: 200px;
background-color: #4CAF50;
position: absolute;
left: -300px; /* 初始状态隐藏在左侧 */
top: 50px;
animation: slideInFromLeft 0.6s ease forwards;
}
@keyframes slideInFromLeft {
to {
transform: translateX(300px); /* 向右移动300px,完全进入视图 */
}
}说明:
如果需要关闭时滑出,可定义另一个关键帧动画:
@keyframes slideOutToLeft {
from {
transform: translateX(300px);
}
to {
transform: translateX(-300px); /* 滑回左侧 */
}
}
/* 使用时切换类名 */
.close-panel {
animation: slideOutToLeft 0.6s ease forwards;
}
用 transform 而非改变 left 值做动画,因为 transform 更高效,不会触发重排基本上就这些,不复杂但容易忽略细节。