自适应图片轮播是一种常见的网页设计功能,它可以根据屏幕大小自动调整图片的显示尺寸和布局。以下是一个简单的JavaScript自适应图片轮播代码示例,包含HTML、CSS和JavaScript部分。
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>自适应图片轮播</title>
<link rel="stylesheet" href="styles.css">
</head>
<body>
<div class="carousel">
<div class="carousel-inner">
<img src="image1.jpg" alt="Image 1">
<img src="image2.jpg" alt="Image 2">
<img src="image3.jpg" alt="Image 3">
</div>
</div>
<script src="script.js"></script>
</body>
</html>
/* styles.css */
body {
margin: 0;
padding: 0;
display: flex;
justify-content: center;
align-items: center;
height: 100vh;
background-color: #f0f0f0;
}
.carousel {
width: 100%;
overflow: hidden;
position: relative;
}
.carousel-inner {
display: flex;
transition: transform 0.5s ease-in-out;
}
.carousel-inner img {
width: 100%;
flex-shrink: 0;
}
// script.js
document.addEventListener('DOMContentLoaded', function() {
const carouselInner = document.querySelector('.carousel-inner');
const images = document.querySelectorAll('.carousel-inner img');
let currentIndex = 0;
function updateCarousel() {
const offset = -currentIndex * 100;
carouselInner.style.transform = `translateX(${offset}%)`;
}
function nextImage() {
currentIndex = (currentIndex + 1) % images.length;
updateCarousel();
}
setInterval(nextImage, 3000); // 每3秒切换一次图片
// 自适应调整
window.addEventListener('resize', () => {
images.forEach(img => img.style.width = '100%');
updateCarousel();
});
});
transform
属性进行动画效果。通过上述代码和解释,你可以实现一个简单的自适应图片轮播,并理解其背后的基本概念和技术细节。
领取专属 10元无门槛券
手把手带您无忧上云