ホームページ >ウェブフロントエンド >フロントエンドQ&A >CSS を使用して簡単な画像切り替え効果を実現する方法

CSS を使用して簡単な画像切り替え効果を実現する方法

PHPz
PHPzオリジナル
2023-04-21 11:24:563143ブラウズ

CSS はフロントエンド開発において最も重要なテクノロジーの 1 つであり、さまざまなスタイルやアニメーションを実現できます。その中で、Webサイトのカルーセルやスライドなど、画像の切り替えも一般的な要件です。今回はCSSを使って簡単に画像切り替え効果を実現する方法を紹介します。

1. HTML 構造

まず、Web ページに画像を追加し、それらに異なる ID またはクラスを割り当てる必要があります。

<div class="slider">
  <img id="img1" src="image1.jpg" alt="Image 1">
  <img id="img2" src="image2.jpg" alt="Image 2">
  <img id="img3" src="image3.jpg" alt="Image 3">
</div>

ご覧のとおり、便宜上、<div> タグ内で class="slider" を使用しています。それらの中の要素を操作します。 <img> タグの ID 属性と src 属性は、それぞれ画像の一意の識別子とソース パスを指定します。

2. CSS スタイル

次に、各画像の CSS スタイルを設定し、CSS セレクターを使用して切り替える必要があります。以下はサンプルコードです:

.slider {
  position: relative;
  height: 400px;
  width: 600px;
  overflow: hidden;
}

.slider img {
  position: absolute;
  top: 0;
  left: 0;
  opacity: 0;
  transition: opacity 0.5s ease;
}

.slider img:first-child {
  opacity: 1;
}

.slider img.active {
  opacity: 1;
}

まず、class="slider"<div> タグに高さを含むいくつかの基本スタイルを設定します。幅を調整してオーバーフローコンテンツを非表示にします。次に、各画像のスタイル(絶対位置、透明度 0、トランジション効果など)を設定します。このうち、.slider img:first-child セレクターは、最初の画像がアクティブであること、つまり Web ページに表示されていることを示します。

3. JS インタラクション

最後に、画像の切り替えを実現するために、JavaScript インタラクションを Web ページに追加する必要があります。以下はサンプル コードです。

var currentImg = 1;
var totalImg = $(".slider img").length;

function changeImg() {
  setInterval(function() {
    currentImg++;
    if (currentImg > totalImg) {
      currentImg = 1;
    }
    $(".slider img").removeClass("active");
    $("#img"+currentImg).addClass("active");
  }, 5000);
}

$(document).ready(function() {
  changeImg();
});

このコードの目的は、現在の画像を表す変数 currentImg と、現在の画像を表す変数 totalImg を定義することです。写真の総数。次に、setInterval 関数を使用して、一定の間隔 (この場合は 5 秒) で changeImg 関数を呼び出します。この関数では、まず現在の画像を更新し、合計数を超えているかどうかを確認してから、CSS セレクターを使用してすべての画像の active クラス名を削除し、そのクラス名を現在の画像に追加します。最後に、Web ページの読み込み時に changeImg 関数を呼び出して画像の切り替えを開始します。

4. エフェクトの表示

上記の 3 つの手順を実行すると、簡単な画像切り替えエフェクトを実現できます。参考までにデモンストレーション効果を示します。

HTMLコード:

<div class="slider">
  <img id="img1" src="https://source.unsplash.com/random/600x400" alt="Image 1">
  <img id="img2" src="https://source.unsplash.com/random/600x401" alt="Image 2">
  <img id="img3" src="https://source.unsplash.com/random/600x402" alt="Image 3">
</div>

CSSコード:

.slider {
  position: relative;
  height: 400px;
  width: 600px;
  overflow: hidden;
}

.slider img {
  position: absolute;
  top: 0;
  left: 0;
  opacity: 0;
  transition: opacity 0.5s ease;
}

.slider img:first-child {
  opacity: 1;
}

.slider img.active {
  opacity: 1;
}

JSコード:

var currentImg = 1;
var totalImg = $(".slider img").length;

function changeImg() {
  setInterval(function() {
    currentImg++;
    if (currentImg > totalImg) {
      currentImg = 1;
    }
    $(".slider img").removeClass("active");
    $("#img"+currentImg).addClass("active");
  }, 5000);
}

$(document).ready(function() {
  changeImg();
});

エフェクト表示: https://codepen.io/fangzhou/pen /oQJNEN

まとめると、CSS を使用して画像切り替え効果を実現するのは難しいことではなく、いくつかの基本的な知識とスキルを習得するだけで済みます。もちろん、実際の開発にはより複雑な状況が含まれる場合があり、継続的な学習と練習が必要です。

以上がCSS を使用して簡単な画像切り替え効果を実現する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。