スライダー/カルーセルは、
スライダー/カルーセル
<!DOCTYPE html>
<html lang="ja">
<head>
<meta charset="UTF-8" />
<meta name="viewport" content="width=device-width, initial-scale=1.0" />
<title>JavaScriptスライダー/カルーセルについて</title>
<link rel="stylesheet" href="./main.css" />
</head>
<body>
<div id="slider">
<div class="slider-item">
<!-- <img src="画像URL" alt="画像が存在しない場合の表示文字" /> -->
画像1
</div>
<div class="slider-item">
<!-- <img src="画像URL" alt="画像が存在しない場合の表示文字" /> -->
画像2
</div>
<div class="slider-item">
<!-- <img src="画像URL" alt="画像が存在しない場合の表示文字" /> -->
画像3
</div>
</div>
<button id="prev">前へ</button>
<button id="next">次へ</button>
<script src="./main.js"></script>
</body>
</html>
// ページの読み込みが完了
document.addEventListener("DOMContentLoaded", function () {
const slider = document.getElementById("slider");
const slides = slider.getElementsByClassName("slider-item");
const prevButton = document.getElementById("prev");
const nextButton = document.getElementById("next");
let currentIndex = 0;
// スライドを非表示にする関数
function hideSlides() {
for (let i = 0; i < slides.length; i++) {
slides[i].style.display = "none";
}
}
// 指定されたインデックスのスライドを表示する関数
function showSlide(index) {
hideSlides();
slides[index].style.display = "block";
}
// 次のスライドを表示する関数
function nextSlide() {
currentIndex = (currentIndex + 1) % slides.length;
showSlide(currentIndex);
}
// 前のスライドを表示する関数
function prevSlide() {
currentIndex = (currentIndex - 1 + slides.length) % slides.length;
showSlide(currentIndex);
}
// 初期表示
showSlide(currentIndex);
// ボタンイベントの設定
nextButton.addEventListener("click", nextSlide);
prevButton.addEventListener("click", prevSlide);
// 一定間隔で自動スライド
setInterval(nextSlide, 5000);
});
#slider {
position: relative;
width: 100%;
max-width: 600px;
overflow: hidden;
margin: auto;
}
/* 画像を差し込んだ場合のデザイン */
/* .slider-item {
display: none;
text-align: center;
}
.slider-item img {
width: 100%;
height: auto;
border-radius: 10px;
box-shadow: 0 4px 8px rgba(0, 0, 0, 0.2);
} */
/* 画像を差し込んで以内デザイン */
.slider-item {
display: none;
text-align: center;
font-size: 2em;
line-height: 300px;
height: 300px;
}
.slider-item:nth-child(1) {
background-color: #bfdd9e;
}
.slider-item:nth-child(2) {
background-color: #56c1db;
}
.slider-item:nth-child(3) {
background-color: #f4af2b;
}
#prev,
#next {
position: absolute;
top: 50%;
transform: translateY(-50%);
background-color: rgba(0, 0, 0, 0.5);
color: white;
border: none;
padding: 10px;
cursor: pointer;
}
#prev {
left: 10px;
}
#next {
right: 10px;
}
#prev:hover,
#next:hover {
background-color: rgba(0, 0, 0, 0.8);
}
出力結果
一定間隔で画像が自動的に切り替わります。前へ・次へボタンで手動で切り替えることもできます。