인터넷의 지속적인 발전으로 이미지 캐러셀은 웹사이트 디자인 및 개발에서 중요한 부분이 되었습니다. 이 글에서는 JavaScript와 CSS를 사용하여 이미지 캐러셀을 만드는 방법을 다룹니다.
먼저 캐러셀의 모양을 설정하려면 HTML 템플릿과 일부 CSS가 필요합니다.
<code class="html"><div class="slider-container"> <div class="slider-wrapper"> <div class="slider-slide"> <img src="image1.jpg"> </div> <div class="slider-slide"> <img src="image2.jpg"> </div> <div class="slider-slide"> <img src="image3.jpg"> </div> <div class="slider-slide"> <img src="image4.jpg"> </div> </div> <button class="slider-prev">❮</button> <button class="slider-next">❯</button> </div></code>
이 HTML 템플릿에서는 별도의 슬라이드쇼로 이미지가 포함된 <div>
요소를 사용합니다. 모든 슬라이드가 포함된 상위 요소에 이러한 슬라이드를 배치하겠습니다. 하단에는 슬라이드쇼를 제어하는 두 개의 "이전" 및 "다음" 버튼도 있습니다. <div>
元素作为一个单独的幻灯片。我们将把这些幻灯片放在一个包含所有幻灯片的父元素中。在底部,我们还有两个控制幻灯片的“prev”和“next”按钮。
接下来,我们将使用CSS来设置这个幻灯片的UI。
<code class="css">.slider-container { position: relative; width: 100%; height: 500px; overflow: hidden; } .slider-wrapper { display: flex; position: absolute; top: 0; left: 0; width: 100%; height: 100%; transition: transform 0.5s ease; } .slider-slide { flex: 1; display: flex; align-items: center; justify-content: center; } .slider-slide img { max-width: 100%; max-height: 100%; object-fit: contain; } .slider-prev, .slider-next { position: absolute; top: 50%; transform: translateY(-50%); width: 50px; height: 50px; border-radius: 50%; background: rgba(0, 0, 0, 0.5); color: white; font-size: 20px; border: none; cursor: pointer; opacity: 0.5; transition: opacity 0.2s ease; } .slider-next { right: 20px; } .slider-prev { left: 20px; } .slider-prev:hover, .slider-next:hover { opacity: 0.8; }</code>
在这个CSS中,我们首先设置了包含轮播的<div>
<code class="javascript">var sliderWrapper = document.querySelector('.slider-wrapper'); var slides = document.querySelectorAll('.slider-slide'); var prevBtn = document.querySelector('.slider-prev'); var nextBtn = document.querySelector('.slider-next'); var slideIndex = 0; function moveSlides() { sliderWrapper.style.transform = "translateX(" + (-slides[slideIndex].offsetLeft) + "px)"; } nextBtn.addEventListener('click', function() { if (slideIndex >= slides.length - 1) { slideIndex = 0; } else { slideIndex++; } moveSlides(); }); prevBtn.addEventListener('click', function() { if (slideIndex <= 0) { slideIndex = slides.length - 1; } else { slideIndex--; } moveSlides(); });</code>
<div>
요소의 위치와 크기를 설정합니다. 그런 다음 슬라이더 래퍼에서 각 슬라이드의 위치와 크기를 설정합니다. 여기서의 비결은 이미지를 중앙에 배치할 수 있도록 각 슬라이드를 플렉스 컨테이너로 만드는 것입니다. 마지막으로 "이전" 및 "다음" 버튼의 위치, 스타일 및 기능을 설정합니다. 이제 캐러셀 슬라이드쇼의 모양과 UI가 설정되었으므로 JavaScript를 사용하여 몇 가지 로직을 추가해야 합니다.
<code class="javascript">var sliderInterval = setInterval(function() { if (slideIndex >= slides.length - 1) { slideIndex = 0; } else { slideIndex++; } moveSlides(); }, 5000); sliderWrapper.addEventListener('mouseenter', function() { clearInterval(sliderInterval); }); sliderWrapper.addEventListener('mouseleave', function() { sliderInterval = setInterval(function() { if (slideIndex >= slides.length - 1) { slideIndex = 0; } else { slideIndex++; } moveSlides(); }, 5000); });</code>
<code class="html"><div class="slider-container"> <div class="slider-wrapper"> <div class="slider-slide"> <img src="image1.jpg"> </div> <div class="slider-slide"> <img src="image2.jpg"> </div> <div class="slider-slide"> <img src="image3.jpg"> </div> <div class="slider-slide"> <img src="image4.jpg"> </div> </div> <button class="slider-prev">❮</button> <button class="slider-next">❯</button> </div> <style> .slider-container { position: relative; width: 100%; height: 500px; overflow: hidden; } .slider-wrapper { display: flex; position: absolute; top: 0; left: 0; width: 100%; height: 100%; transition: transform 0.5s ease; } .slider-slide { flex: 1; display: flex; align-items: center; justify-content: center; } .slider-slide img { max-width: 100%; max-height: 100%; object-fit: contain; } .slider-prev, .slider-next { position: absolute; top: 50%; transform: translateY(-50%); width: 50px; height: 50px; border-radius: 50%; background: rgba(0, 0, 0, 0.5); color: white; font-size: 20px; border: none; cursor: pointer; opacity: 0.5; transition: opacity 0.2s ease; } .slider-next { right: 20px; } .slider-prev { left: 20px; } .slider-prev:hover, .slider-next:hover { opacity: 0.8; } </style> <script> var sliderWrapper = document.querySelector('.slider-wrapper'); var slides = document.querySelectorAll('.slider-slide'); var prevBtn = document.querySelector('.slider-prev'); var nextBtn = document.querySelector('.slider-next'); var slideIndex = 0; function moveSlides() { sliderWrapper.style.transform = "translateX(" + (-slides[slideIndex].offsetLeft) + "px)"; } nextBtn.addEventListener('click', function() { if (slideIndex >= slides.length - 1) { slideIndex = 0; } else { slideIndex++; } moveSlides(); }); prevBtn.addEventListener('click', function() { if (slideIndex <= 0) { slideIndex = slides.length - 1; } else { slideIndex--; } moveSlides(); }); var sliderInterval = setInterval(function() { if (slideIndex >= slides.length - 1) { slideIndex = 0; } else { slideIndex++; } moveSlides(); }, 5000); sliderWrapper.addEventListener('mouseenter', function() { clearInterval(sliderInterval); }); sliderWrapper.addEventListener('mouseleave', function() { sliderInterval = setInterval(function() { if (slideIndex >= slides.length - 1) { slideIndex = 0; } else { slideIndex++; } moveSlides(); }, 5000); }); </script></code>
위 내용은 자바스크립트 CSS에서 이미지 캐러셀 블록을 설정하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!