1画面に複数の画像を表示するカルーセルを作る方法【HTML/CSS/JavaScript・サンプルコード付き】

カルーセル

1画面に複数の画像を表示するカルーセルを作る方法

1画面に複数の画像を表示するカルーセルをHTML・CSS・JavaScriptで作る方法を紹介します。1枚ずつ大きく切り替えるカルーセルではなく、複数の画像を横並びで表示しながら、左右のボタンで次の画像へスライドできるサンプルです。

このサンプルでは、画像を横一列に並べ、表示エリアからはみ出した部分を隠すことでカルーセルの見た目を作成します。JavaScriptで現在位置を管理し、前へ・次へボタンをクリックすると画像一覧が横へ移動します。画面幅に合わせて表示枚数も変わるため、パソコン・タブレット・スマホでも使いやすい構成です。

写真ギャラリー、制作実績、商品画像、旅行写真、バナー一覧など、複数の画像を限られたスペースで見せたい場面に向いています。画像ファイルを差し替えるだけで利用できるため、シンプルな画像カルーセルを作りたい場合にも導入しやすいサンプルです。

コードについて 本記事のコードはサンプルコードです。ご利用前に必ず動作確認を行ってください。
免責事項 本コードの利用により発生した損害について、当サイトは一切の責任を負いません。

デモ

矢印ボタンをおしゃれにして 全分書き出して

コードをコピーして使おう!

<!DOCTYPE html>
<html lang="ja">
<head>

  <!-- 文字コード -->
  <meta charset="UTF-8">

  <!-- スマホ表示に対応 -->
  <meta name="viewport" content="width=device-width, initial-scale=1.0">

  <!-- ページタイトル -->
  <title>1画面に複数の画像を表示するカルーセル</title>

  <!-- CSSファイルを読み込み -->
  <link rel="stylesheet" href="style.css">

</head>
<body>

  <!-- カルーセル全体 -->
  <div class="multi-image-carousel_demo">

    <!-- 画像表示エリア -->
    <div class="multi-image-carousel_view">

      <!-- 横に並べる画像一覧 -->
      <div class="multi-image-carousel_track" id="multi-image-carousel-track">

        <!-- 画像1:imagesフォルダに配置した画像ファイル名へ変更 -->
        <div class="multi-image-carousel_item">
          <img src="images/【配置した画像のファイル名1】" alt="画像1">
        </div>

        <!-- 画像2:imagesフォルダに配置した画像ファイル名へ変更 -->
        <div class="multi-image-carousel_item">
          <img src="images/【配置した画像のファイル名2】" alt="画像2">
        </div>

        <!-- 画像3:imagesフォルダに配置した画像ファイル名へ変更 -->
        <div class="multi-image-carousel_item">
          <img src="images/【配置した画像のファイル名3】" alt="画像3">
        </div>

        <!-- 画像4:imagesフォルダに配置した画像ファイル名へ変更 -->
        <div class="multi-image-carousel_item">
          <img src="images/【配置した画像のファイル名4】" alt="画像4">
        </div>

        <!-- 画像5:imagesフォルダに配置した画像ファイル名へ変更 -->
        <div class="multi-image-carousel_item">
          <img src="images/【配置した画像のファイル名5】" alt="画像5">
        </div>

        <!-- 画像6:imagesフォルダに配置した画像ファイル名へ変更 -->
        <div class="multi-image-carousel_item">
          <img src="images/【配置した画像のファイル名6】" alt="画像6">
        </div>

      </div>

    </div>

    <!-- 前へ・次へボタン -->
    <div class="multi-image-carousel_buttons">
      <button type="button" id="multi-image-carousel-prev" aria-label="前へ">前へ</button>
      <button type="button" id="multi-image-carousel-next" aria-label="次へ">次へ</button>
    </div>

  </div>

  <!-- JavaScriptファイルを読み込み -->
  <script src="script.js"></script>

</body>
</html>

ファイル構成と設置方法

このサンプルは、HTML・CSS・JavaScriptの3ファイルで構成されています。HTMLにはカルーセルのレイアウト、CSSには複数画像を横並びで表示するデザインやレスポンシブ対応、JavaScriptには前へ・次へボタンによるスライド処理を記述しています。サンプル画像は含まれていないため、画像はご自身で用意してください。また、sampleフォルダ内にimagesフォルダを作成し、その中へ使用する画像を配置してください。

sample/
├── index.html
├── style.css
├── script.js
└── images/   ← このフォルダは自分で作成
    ├── 画像1.jpg
    ├── 画像2.jpg
    ├── 画像3.jpg
    ├── 画像4.jpg
    ├── 画像5.jpg
    └── 画像6.jpg

sample/index.htmlをブラウザで開くとカルーセルを確認できます。画像はsample/images/へ配置し、index.html内の画像ファイル名を配置した画像名へ変更してください。画像を増減する場合はHTMLの画像ブロックを追加・削除するだけで対応できます。スライド速度はstyle.csstransition: transform .5s ease;で変更でき、.5sを大きくするとゆっくり、小さくすると速くなります。


コメント