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属性をもたせることをおすすめします。詳しくはこのドキュメントを参考にしてください。