カルーセル
カルーセルのように要素 (画像またはテキストのスライド) を循環するためのスライドショー コンポーネント。
カルーセルは、CSS 3D 変換と少しの JavaScript で構築された、一連のコンテンツを循環するためのスライドショーです。一連の画像、テキスト、またはカスタム マークアップで動作します。また、前/次のコントロールとインジケーターのサポートも含まれています。
Page Visibility APIがサポートされているブラウザーでは、Web ページがユーザーに表示されていない場合 (ブラウザー タブが非アクティブである場合、ブラウザー ウィンドウが最小化されている場合など)、カルーセルはスライドを回避します。
ネストされたカルーセルはサポートされておらず、通常、カルーセルはアクセシビリティ標準に準拠していないことに注意してください。
最後に、ソースから JavaScript をビルドする場合はutil.js
、 .
カルーセルは、スライドの寸法を自動的に正規化しません。そのため、コンテンツのサイズを適切に設定するには、追加のユーティリティまたはカスタム スタイルを使用する必要がある場合があります。カルーセルは前/次のコントロールとインジケーターをサポートしていますが、明示的に必須ではありません。必要に応じて追加およびカスタマイズします。
.carousel
特に 1 つのページで複数のカルーセルを使用している場合は、オプションのコントロールに一意の ID を設定してください。
これは、スライドのみのカルーセルです。ブラウザのデフォルトの画像配置を防ぐために、カルーセル画像に.d-block
とが存在することに注意してください。.img-fluid
<div id="carouselExampleSlidesOnly" class="carousel slide" data-ride="carousel">
<div class="carousel-inner">
<div class="carousel-item active">
<img class="d-block w-100" src="..." alt="First slide">
</div>
<div class="carousel-item">
<img class="d-block w-100" src="..." alt="Second slide">
</div>
<div class="carousel-item">
<img class="d-block w-100" src="..." alt="Third slide">
</div>
</div>
</div>
前のコントロールと次のコントロールを追加します。
<div id="carouselExampleControls" class="carousel slide" data-ride="carousel">
<div class="carousel-inner">
<div class="carousel-item active">
<img class="d-block w-100" src="..." alt="First slide">
</div>
<div class="carousel-item">
<img class="d-block w-100" src="..." alt="Second slide">
</div>
<div class="carousel-item">
<img class="d-block w-100" src="..." alt="Third slide">
</div>
</div>
<a class="carousel-control-prev" href="#carouselExampleControls" role="button" data-slide="prev">
<span class="carousel-control-prev-icon" aria-hidden="true"></span>
<span class="sr-only">Previous</span>
</a>
<a class="carousel-control-next" href="#carouselExampleControls" role="button" data-slide="next">
<span class="carousel-control-next-icon" aria-hidden="true"></span>
<span class="sr-only">Next</span>
</a>
</div>
コントロールと一緒に、カルーセルにインジケーターを追加することもできます。
<div id="carouselExampleIndicators" class="carousel slide" data-ride="carousel">
<ol class="carousel-indicators">
<li data-target="#carouselExampleIndicators" data-slide-to="0" class="active"></li>
<li data-target="#carouselExampleIndicators" data-slide-to="1"></li>
<li data-target="#carouselExampleIndicators" data-slide-to="2"></li>
</ol>
<div class="carousel-inner">
<div class="carousel-item active">
<img class="d-block w-100" src="..." alt="First slide">
</div>
<div class="carousel-item">
<img class="d-block w-100" src="..." alt="Second slide">
</div>
<div class="carousel-item">
<img class="d-block w-100" src="..." alt="Third slide">
</div>
</div>
<a class="carousel-control-prev" href="#carouselExampleIndicators" role="button" data-slide="prev">
<span class="carousel-control-prev-icon" aria-hidden="true"></span>
<span class="sr-only">Previous</span>
</a>
<a class="carousel-control-next" href="#carouselExampleIndicators" role="button" data-slide="next">
<span class="carousel-control-next-icon" aria-hidden="true"></span>
<span class="sr-only">Next</span>
</a>
</div>
初期アクティブ要素が必要
クラスをスライドの.active
1 つに追加する必要があります。そうしないと、カルーセルが表示されません。
.carousel-caption
any 内の要素を使用して、スライドにキャプションを簡単に追加します.carousel-item
。以下に示すように、オプションの表示ユーティリティを使用して、小さなビューポートで簡単に非表示にすることができます。最初は で非表示にし、 で.d-none
中規模のデバイスに戻します.d-md-block
。
データ属性を使用して、カルーセルの位置を簡単に制御します。現在の位置に相対的なスライド位置を変更するdata-slide
キーワードprev
またはを受け入れます。または、未加工のスライド インデックスをカルーセルに渡すためnext
に使用します。これにより、スライドの位置が で始まる特定のインデックスに移動します。data-slide-to
data-slide-to="2"
0
このdata-ride="carousel"
属性は、カルーセルをページの読み込みからアニメーション化するようにマークするために使用されます。同じカルーセルの (冗長で不要な) 明示的な JavaScript 初期化と組み合わせて使用することはできません。
次のように手動でカルーセルを呼び出します。
オプションは、データ属性または JavaScript を介して渡すことができます。data-
データ属性の場合、オプション名をのようにに追加しますdata-interval=""
。
名前 | タイプ | デフォルト | 説明 |
---|---|---|---|
間隔 | 番号 | 5000 | アイテムを自動的に循環させるまでの遅延時間。false の場合、カルーセルは自動的に循環しません。 |
キーボード | ブール値 | 真実 | カルーセルがキーボード イベントに反応するかどうか。 |
一時停止 | 文字列 | ブール値 | 「ホバー」 | に設定すると タッチ対応デバイスでは、 に設定すると、自動的に再開する前に (ユーザーがカルーセルとの対話を終了すると) 2 つの間隔で |
乗る | ストリング | 間違い | ユーザーが最初のアイテムを手動で循環させた後、カルーセルを自動再生します。「カルーセル」の場合、読み込み時にカルーセルを自動再生します。 |
包む | ブール値 | 真実 | カルーセルが連続して循環するか、ハードストップを行うか。 |
非同期メソッドと遷移
すべての API メソッドは非同期であり、遷移を開始します。トランジションが開始されるとすぐに呼び出し元に戻りますが、トランジションが終了する前に戻ります。さらに、遷移中のコンポーネントでのメソッド呼び出しは無視されます。
オプションのオプションでカルーセルを初期化し、object
アイテムの循環を開始します。
カルーセル アイテムを左から右に循環します。
カルーセルがアイテムを循環するのを止めます。
カルーセルを特定のフレーム (0 ベース、配列と同様) に切り替えます。ターゲット アイテムが表示される前 (つまり、イベントが発生する前)に呼び出し元に戻ります。slid.bs.carousel
前の項目に循環します。前の項目が表示される前 (つまり、イベントが発生する前)に呼び出し元に戻ります。slid.bs.carousel
次のアイテムに循環します。次の項目が表示される前 (つまり、イベントが発生する前)に呼び出し元に戻ります。slid.bs.carousel
要素のカルーセルを破棄します。
Bootstrap のカルーセル クラスは、カルーセル機能にフックするための 2 つのイベントを公開します。両方のイベントには、次の追加のプロパティがあります。
direction
: カルーセルがスライドする方向 ("left"
または"right"
)。relatedTarget
: アクティブなアイテムとして配置される DOM 要素。from
: 現在のアイテムのインデックスto
: 次の項目のインデックス
すべてのカルーセル イベントは、カルーセル自体 (つまり<div class="carousel">
) で発生します。
イベントタイプ | 説明 |
---|---|
slide.bs.carousel | slide このイベントは、インスタンス メソッドが呼び出されるとすぐに発生します。 |
スライド bs カルーセル | このイベントは、カルーセルがスライド遷移を完了したときに発生します。 |