10
10

More than 5 years have passed since last update.

【slick.js】スマホでautoplayが止まる現象の対策

Posted at

slickでautoplay設定をしていたが、スマホで見たときに画像をタッチしながらスクロールしたらautoplayが止まる現象が起きた。そんな時の対策をメモ。

ちなみに今回、スライドアニメーションは「fade」にしていた。

<div class="mv_sp">
      <img src="images/mv1_sp.jpg" alt="">
      <img src="images/mv2_sp.jpg" alt="">
      <img src="images/mv3_sp.jpg" alt="">
</div>

対策1. autoplay止まる系オプションを無効に

何らかのアクションでautoplayが止まるのを有効にしてしまうオプションがある。
とりあえず下記オプション全てをfalseに設定

  • pauseOnFocus:フォーカスで一時停止
  • pauseOnHover:マウスホバーで一時停止
  • pauseOnDotsHover:ドットナビをマウスホバーで一時停止
$('.mv_sp').slick({
    arrows: false,
    autoplay: true,
    autoplaySpeed: 5000,
    speed: 1500,
    fade: true,
    pauseOnFocus: false,
    pauseOnHover: false,
    pauseOnDotsHover: false,
    waitForAnimate: false
  });

→ 解決ならず・・・

対策2. タッチ操作イベントにautoplayを動かす処理を追加

・スマホでタッチしながらスクロールする操作は、touchmoveイベントで制御できそうとみる。
・イベントに対してautoplayをスタートするslickPlayメソッドを設定。

$('.mv_sp').on('touchmove', function(event, slick, currentSlide, nextSlide){
    $('.mv_sp').slick('slickPlay');
  });

→ 無事解決!

10
10
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
10
10