JavaScript滑屏特效是一种常见的网页交互设计,它允许用户通过滑动屏幕或鼠标来触发页面上的动画效果。这种特效可以增强用户体验,使网站更加生动和吸引人。
滑屏特效通常涉及到以下几个基础概念:
touchstart
、touchmove
、touchend
(触摸屏设备)或mousedown
、mousemove
、mouseup
(鼠标操作)。requestAnimationFrame
来实现平滑的动画效果。以下是一个简单的水平滑屏特效示例:
<!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;
}
.slide {
width: 100%;
height: 300px;
display: flex;
justify-content: center;
align-items: center;
font-size: 2em;
color: white;
position: absolute;
transition: transform 0.5s ease-in-out;
}
.slide:nth-child(1) { background-color: #3498db; }
.slide:nth-child(2) { background-color: #2ecc71; }
.slide:nth-child(3) { background-color: #e74c3c; }
</style>
</head>
<body>
<div class="slider">
<div class="slide">Slide 1</div>
<div class="slide">Slide 2</div>
<div class="slide">Slide 3</div>
</div>
<script>
let startX = 0;
let currentTranslate = 0;
let prevTranslate = 0;
let animationID = 0;
let currentIndex = 0;
const slider = document.querySelector('.slider');
const slides = document.querySelectorAll('.slide');
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 < slides.length - 1) currentIndex += 1;
if (movedBy > 100 && currentIndex > 0) currentIndex -= 1;
prevTranslate = currentTranslate;
setSliderPosition();
}
function setSliderPosition() {
const slideWidth = slider.offsetWidth;
currentTranslate = -currentIndex * slideWidth;
slides.forEach((slide, index) => {
slide.style.transform = `translateX(${currentTranslate}px)`;
});
}
</script>
</body>
</html>
transform
属性来减少重绘和回流,或者使用will-change
属性来提示浏览器提前优化。touchmove
事件中正确地获取和处理坐标值,避免因浏览器默认行为(如滚动)影响计算结果。通过以上方法,可以有效地实现和优化JavaScript滑屏特效。
领取专属 10元无门槛券
手把手带您无忧上云