JavaScript 触摸横向滑动导航主要利用触摸事件(如 touchstart
, touchmove
, touchend
)来实现用户在触摸屏设备上的横向滑动操作。这种导航方式常见于移动应用和响应式网站,用于在多个页面或视图之间进行切换。
transform
和 transition
属性来实现滑动效果。以下是一个简单的基于 JavaScript 和 CSS 的横向滑动导航示例:
<div class="slider-container">
<div class="slider">
<div class="slide">Slide 1</div>
<div class="slide">Slide 2</div>
<div class="slide">Slide 3</div>
</div>
</div>
.slider-container {
width: 100%;
overflow: hidden;
}
.slider {
display: flex;
transition: transform 0.3s ease-in-out;
}
.slide {
min-width: 100%;
text-align: center;
}
const slider = document.querySelector('.slider');
let startX = 0;
let currentTranslate = 0;
let prevTranslate = 0;
let animationID = 0;
let currentIndex = 0;
slider.addEventListener('touchstart', touchStart);
slider.addEventListener('touchmove', touchMove);
slider.addEventListener('touchend', touchEnd);
function touchStart(event) {
startX = event.touches[0].clientX;
cancelAnimationFrame(animationID);
}
function touchMove(event) {
const currentX = event.touches[0].clientX;
currentTranslate = prevTranslate + currentX - startX;
}
function touchEnd() {
const movedBy = currentTranslate - prevTranslate;
if (movedBy < -100 && currentIndex < 2) currentIndex += 1;
if (movedBy > 100 && currentIndex > 0) currentIndex -= 1;
prevTranslate = currentTranslate;
setSliderPosition();
}
function setSliderPosition() {
slider.style.transform = `translateX(${currentIndex * -100}%)`;
}
原因:可能是由于频繁的重绘和回流导致的性能问题。
解决方法:
requestAnimationFrame
来优化动画性能。原因:触摸事件的坐标获取可能存在误差。
解决方法:
touchstart
和 touchmove
中记录初始坐标和当前坐标,计算差值来确定滑动距离。通过以上方法,可以有效提升横向滑动导航的用户体验和应用性能。
领取专属 10元无门槛券
手把手带您无忧上云