Slider Progress
スライダーの現在地表示
v3用のドキュメントを参照しています
Slider Progress
はじめに
このチュートリアルでは、下の例のような、現在地をバーで表示する方法を解説します。
- 01
- 02
- 03
- 04
- 05
- 06
- 07
- 08
- 09
HTMLとCSS
まず、バー自体をHTMLとCSSで実装します。
<divclass="splide"><divclass="splide__track"><ulclass="splide__list"><liclass="splide__slide">Slide01</li>...</ul></div><!-- 現在地表示用のバーを実装 --><divclass="my-slider-progress"><divclass="my-slider-progress-bar"></div></div></div>HTML
<div class="splide"> <div class="splide__track"> <ul class="splide__list"> <li class="splide__slide">Slide 01</li> ... </ul> </div> <!-- 現在地表示用のバーを実装 --> <div class="my-slider-progress"> <div class="my-slider-progress-bar"></div> </div> </div>
.my-slider-progress{background:#ccc;}.my-slider-progress-bar{background:greenyellow;height:2px;transition:width400msease;width:0;}CSS
.my-slider-progress { background: #ccc; } .my-slider-progress-bar { background: greenyellow; height: 2px; transition: width 400ms ease; width: 0; } トランジションの時間は、スライダーのスピード(options.speed)と一致させると一体感が生まれます。
スクリプトによる制御
「いま全体のどのあたりにいるのか」を表す割合は、現在のインデックスと終わりのインデックスから( current + 1 ) / ( end + 1 )として計算できます。現在のインデックスはSplide#indexから、終わりのインデックスはController#getEnd()から得られます。
これらの値を利用して、スライダーが動くたびにバーの幅を更新する処理を書いてみましょう。
varsplide=newSplide('.splide');varbar=splide.root.querySelector('.my-slider-progress-bar');// バーの幅を更新するsplide.on('mounted move',function(){varend=splide.Components.Controller.getEnd()+1;bar.style.width=String(100*(splide.index+1)/end)+'%';});splide.mount();JavaScript
var splide = new Splide( '.splide' ); var bar = splide.root.querySelector( '.my-slider-progress-bar' ); // バーの幅を更新する splide.on( 'mounted move', function () { var end = splide.Components.Controller.getEnd() + 1; bar.style.width = String( 100 * ( splide.index + 1 ) / end ) + '%'; } ); splide.mount(); スライダーがロードされた直後にも幅を更新するため、上の例ではmountedイベントが配信された際にも更新処理を走らせました。
補足
あと少し処理を加えることで、クリック可能なバーを作成できます。
- クリックされた場所とバーの全長をもとに、インデックスを逆算する
- スライダーを
Splide#go()で移動させる
ただしこの場合はアクセシビリティの観点から、aria-controlsやaria-valuenowなどのARIA属性をもたせることをおすすめします。詳しくはこのドキュメントを参考にしてください。