// HTML
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<link rel="stylesheet" href="style.css">
<title>Carousel</title>
</head>
<body>
<div class="carousel-container">
<div class="carousel-slide">
<img src="./w5.jpg" id="lastClone">
<img src="./w1.jpg">
<img src="./w2.png">
<img src="./w3.jpg">
<img src="./w4.jpg">
<img src="./w5.jpg">
<img src="./w1.jpg" id="firstClone">
</div>
</div>
<button id="prevBtn">Prev</button>
<button id="nextBtn">Next</button>
<script type="text/javascript"></script>
<script src="script.js"></script>
</body>
</html>
// CSS
*{
padding: 0px;
margin: 0px;
box-sizing: border-box;
}
.carousel-container{
width: 60%;
margin-left: 0px;
border: 2px solid black;
}
.carousel-slide{
display: flex;
width: 100%;
height: 500px;
}
#prevBtn{
color: black;
}
#nextBtn{
color: black;
}
// Javascript
const carouselSlide = document.querySelector('.carousel-slide');
const carouselImages = document.querySelectorAll('.carousel-slide img')
const prevBtn = document.querySelector('#prevBtn');
const nextBtn = document.querySelector('#nextBtn');
let counter = 1;
const size = carouselImages[0].clientWidth;
carouselSlide.style.transform = 'translateX(' + (-size * counter) + 'px)';
nextBtn.addEventListener('click', function(){
if(counter <= 0){return }
carouselSlide.style.transition = "transform 0.4s ease-in-out";
counter++;
console.log(counter);
carouselSlide.style.transform = 'translateX(' + (-size * counter) + 'px)';
})
prevBtn.addEventListener('click', function(){
carouselSlide.style.transition = "transform 0.4s ease-in-out";
counter--;
console.log(counter);
carouselSlide.style.transform = 'translateX(' + (-size * counter) + 'px)';
})