[118]
31 Июл 2018, 23:42

Swiper, Vue-touch + Hammer.js — пара touch-ориентированных реализаций слайдеров и каруселей

Недавно пришлось окунуться с головой в казалось бы простую область — листалки картинок.
Начнем с того, что bootstrap carousel без танцев с бубном не поддерживает тачскрины. То есть, листать стрелками туда-сюда ты можешь без проблем, но на свайп по экрану реакции никакой, что заставляет грустить, так как bootstrap повсюду и его карусель в остальном решает большинство подобных задач.

Ну ок. Поскольку в проекте, который сподвиг на эти исследования, использовался vue — мы обратили внимание на vue-touch. Что является надстройкой над Hammer и в общем, достаточно просто решает задачу:

import Vue from 'vue';
import VueTouch from 'vue-touch';
import App from 'App.vue';

Vue.use(VueTouch);
new Vue({
   el: '#app',
   render: h => h(App)
});

 

<template>
   <div>
      <v-touch @swipeleft="doSomething">
          <p>I can now be swiped on!</p>
      </v-touch>
      <v-touch @rotate="rotateAThing">
          <p>Rotate me!</p>
      </v-touch>
  </div>
</template>

Все отлично, все работает. Но во первых: для jQuery 3 которая используется с 4-м бутстрапом, нужно устанавливать бета-версию, которая надо сказать, местами лагает. 
Во-вторых, и самое главное: это не готовое решение — да, vue-touch это настройка над Hammer, которая в принципе делает работу с ним удобнее — но. Все равно, приходится работать с событиями — pan, panleft, panright, panstart, panend и т. п., и если нужно делать какое-то кастомное поведение — вручную их комбинировать и использовать разные обработчики событий для каждого этапа движения — неудобно. 

Вариант 2 — Swiper
Полостью готовое решение, все удобно и компактно. Как в Bootstrap — выбрал то, что тебе надо, скопировал код — и вуаля, все работает. При этом, выбор вариантов огромен. Однозначно, на сегодня Swiper — чемпион, рекомендую!

Пример:

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="utf-8">
  <title>Swiper demo</title>
  <!-- Link Swiper's CSS -->
  <link rel="stylesheet" href="../dist/css/swiper.min.css">

  <!-- Demo styles -->
  <style>
    html, body {
      position: relative;
      height: 100%;
    }
    body {
      background: #eee;
      font-family: Helvetica Neue, Helvetica, Arial, sans-serif;
      font-size: 14px;
      color:#000;
      margin: 0;
      padding: 0;
    }
    .swiper-container {
      width: 100%;
      height: 100%;
    }
    .swiper-slide {
      text-align: center;
      font-size: 18px;
      background: #fff;

      /* Center slide text vertically */
      display: -webkit-box;
      display: -ms-flexbox;
      display: -webkit-flex;
      display: flex;
      -webkit-box-pack: center;
      -ms-flex-pack: center;
      -webkit-justify-content: center;
      justify-content: center;
      -webkit-box-align: center;
      -ms-flex-align: center;
      -webkit-align-items: center;
      align-items: center;
    }
  </style>
</head>
<body>
  <!-- Swiper -->
  <div class="swiper-container">
    <div class="swiper-wrapper">
      <div class="swiper-slide">Slide 1</div>
      <div class="swiper-slide">Slide 2</div>
      <div class="swiper-slide">Slide 3</div>
      <div class="swiper-slide">Slide 4</div>
      <div class="swiper-slide">Slide 5</div>
      <div class="swiper-slide">Slide 6</div>
      <div class="swiper-slide">Slide 7</div>
      <div class="swiper-slide">Slide 8</div>
      <div class="swiper-slide">Slide 9</div>
      <div class="swiper-slide">Slide 10</div>
    </div>
    <!-- Add Pagination -->
    <div class="swiper-pagination"></div>
    <!-- Add Arrows -->
    <div class="swiper-button-next"></div>
    <div class="swiper-button-prev"></div>
  </div>

  <!-- Swiper JS -->
  <script src="../dist/js/swiper.min.js"></script>

  <!-- Initialize Swiper -->
  <script>
    var swiper = new Swiper('.swiper-container', {
      pagination: {
        el: '.swiper-pagination',
        type: 'fraction',
      },
      navigation: {
        nextEl: '.swiper-button-next',
        prevEl: '.swiper-button-prev',
      },
    });
  </script>
</body>
</html>
Комментарии (0)

Добавить комментарий

Войдите, чтобы написать о чем-нибудь...
Вход Регистрация
Web.onRails
Здесь вы можете спросить или написать обо всём, что касается Веб-разработки.
написать о чем-нибудь...
Метки:
Нетология
Лучшее
[49]
17 Сен 2011, 15:13
FileZilla перетаскивание файлов
[просмотров 978]
[2]
26 Июн 2018, 23:10
Как в React сделать поле input file с кнопкой?
[просмотров 971]
[315]
16 Июл 2011, 20:03
Python работа с MySQL
[просмотров 832]
[58]
29 мая 2012, 12:08
Узнать версию PHP из командной строки
[просмотров 828]
[74]
31 мая 2011, 11:48
Python проверка существования переменной
[просмотров 822]
[118]
21 Июл 2011, 14:04
Python Imaging Library (PIL)
[просмотров 805]
[52]
16 Окт 2011, 15:38
Вывести все элементы POST
[просмотров 764]
[4]
19 Июн 2018, 16:24
React и ReactDOM
[просмотров 665]
Aliexpress WW