JavaScript 触屏左右滑动图片主要涉及到触摸事件(Touch Events)和页面元素的动画效果。触摸事件包括 touchstart
、touchmove
和 touchend
,这些事件允许开发者响应用户的触摸操作。通过监听这些事件并计算触摸点的移动距离和方向,可以实现图片的左右滑动效果。
transition
和 transform
属性实现平滑的滑动效果。<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>触屏左右滑动图片</title>
<style>
.slider {
width: 100%;
overflow: hidden;
position: relative;
}
.slider-container {
display: flex;
transition: transform 0.3s ease;
}
.slider-container img {
width: 100%;
flex-shrink: 0;
}
</style>
</head>
<body>
<div class="slider" id="slider">
<div class="slider-container" id="sliderContainer">
<img src="image1.jpg" alt="Image 1">
<img src="image2.jpg" alt="Image 2">
<img src="image3.jpg" alt="Image 3">
</div>
</div>
<script>
let startX = 0;
let currentTranslate = 0;
let prevTranslate = 0;
let animationID = 0;
const sliderContainer = document.getElementById('sliderContainer');
const images = document.querySelectorAll('.slider-container img');
let currentIndex = 0;
sliderContainer.addEventListener('touchstart', touchStart);
sliderContainer.addEventListener('touchmove', touchMove);
sliderContainer.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 < images.length - 1) currentIndex += 1;
if (movedBy > 100 && currentIndex > 0) currentIndex -= 1;
prevTranslate = currentTranslate;
setSliderPosition();
}
function setSliderPosition() {
sliderContainer.style.transform = `translateX(${currentIndex * -100}%)`;
}
</script>
</body>
</html>
问题1:滑动不够流畅
原因:可能是由于页面重绘和回流导致的性能问题。
解决方法:
transform
和 opacity
属性来实现动画,因为这些属性不会触发重绘和回流。requestAnimationFrame
来优化动画性能。问题2:滑动方向判断不准确
原因:触摸点的移动距离计算不准确。
解决方法:
touchmove
事件中精确计算触摸点的移动距离。通过以上方法,可以有效解决触屏左右滑动图片时可能遇到的问题,并提升用户体验。
领取专属 10元无门槛券
手把手带您无忧上云