• Главная
  • Контакты
Подписаться:
  • Twitter
  • Facebook
  • RSS
  • VK
  • PushAll
logo

logo

  • Все
    • Положительные
    • Отрицательные
  • За сегодня
    • Положительные
    • Отрицательные
  • За вчера
    • Положительные
    • Отрицательные
  • За 3 дня
    • Положительные
    • Отрицательные
  • За неделю
    • Положительные
    • Отрицательные
  • За месяц
    • Положительные
    • Отрицательные
  • За год
    • Положительные
    • Отрицательные
  • Сортировка
    • По дате (возр)
    • По дате (убыв)
    • По рейтингу (возр)
    • По рейтингу (убыв)
    • По комментам (возр)
    • По комментам (убыв)
    • По просмотрам (возр)
    • По просмотрам (убыв)
Главная
  • Все
    • Положительные
    • Отрицательные
  • За сегодня
    • Положительные
    • Отрицательные
  • За вчера
    • Положительные
    • Отрицательные
  • За 3 дня
    • Положительные
    • Отрицательные
  • За неделю
    • Положительные
    • Отрицательные
  • За месяц
    • Положительные
    • Отрицательные
  • Главная
  • Карусель на Vanilla.JS

Карусель на Vanilla.JS +11

24.04.2017 11:59
iGetPass 18 5300 Источник
Разработка веб-сайтов*, JavaScript*
Прочитав эту статью решил запилить свою карусель с блэк-джеком и jQuery хотя нет, без него ибо 2017 год и он не особо и нужен. Создадим функцию, которая принимает объект с параметрами, и делает слайдер. Некоторые моменты будут опущены, такие, как: вендорные префиксы, таймер смены и т.д.
Первое что мы сделаем — разметка для карусели, на классах, а не id, дабы можно было использовать несколько раз один и тот же модуль на странице, ну и специфичность не была 3-его порядка.

HTML
<div class="wrap">
	<div class="b-carousel js-carousel">
		<button class="b-carousel__prev js-carousel__prev">Prev</button>
		<button class="b-carousel__next js-carousel__next">Next</button>
		<div class="b-carousel__wrap js-carousel__wrap">
			<div class="b-carousel__item">
				<img src="..." alt="" class="b-carousel__img">
			</div>
			<div class="b-carousel__item">
				<img src="..." alt="" class="b-carousel__img">
			</div>
			<div class="b-carousel__item">
				<img src="..." alt="" class="b-carousel__img">
			</div>
			<div class="b-carousel__item">
				<img src="..." alt="" class="b-carousel__img">
			</div>
		</div>
	</div>
</div>


У нас есть:

  • Блок — обертка для карусели, который скрывает все, что вылезает за его рамки;
  • Контейнер для самих слайдов, которые будут располагаться в строчку, с помощью flexbox, можем себе это позволить;
  • Блоки слайдов, которые скрывают все, что вылезает за их границы;
  • Блок – хелпер для выравнивания картинки по вертикали. И, внутри него уже будем располагать картинки.

В CSS используем БЭМ нотификацию, ибо не засоряем глобальную область. Сделаем его чуть-чуть адаптивным.

CSS
.b-carousel {
	width: 100%;
	overflow: hidden;
	position: relative;

	box-sizing: border-box;
	border: 1px solid;
}

	.b-carousel__prev,
	.b-carousel__next {
		position: absolute;
		top: 50%;
		left: 20px;
		width: 50px;
		height: 50px;
		background: #fff;
		transform: translateY(-50%) translateZ(0);
		cursor: pointer;
		text-indent: 100%;
		white-space: nowrap;
		overflow: hidden;
		z-index: 3;
	}

		.b-carousel__next {
			left: auto;
			right: 20px;
		}

	.b-carousel__wrap {
		display: flex;
		transition: transform .5s;
		will-change: transform;
		position: relative;
		z-index: 1;
		height: 100%;
	}

		.b-carousel__item {
			flex: 0 0 100%;
			overflow: hidden;
			display: flex;
			align-items: center;
			justify-content: center;
		}

			.b-carousel__img {
				width: 100%;
				display: block;
			}


Transform: translateZ(0) у контролов — хак для вынесения их на отдельный композитный слой, чтобы при смещении контейнера со слайдами не было перерисовки кнопок. А у обертки свойство will-change. Оно для броузера, чтобы он знал, что с блоком будут происходить какие-то действия.

Да начнем писать код. Создадим функцию, которая принимает объект с параметрами:

function Carousel(setting) {

	/* Scope privates methods and properties */
	let privates = {};

	/* Privates properties */
	privates.setting = setting;

	privates.sel = {
		"main": document.querySelector(privates.setting.main),
		"wrap": document.querySelector(privates.setting.wrap),
		"children": document.querySelector(privates.setting.wrap).children,
		"prev": document.querySelector(privates.setting.prev),
		"next": document.querySelector(privates.setting.next)
	};

	privates.opt = {
		"position": 0,
		"max_position": document.querySelector(privates.setting.wrap).children.length
	};

	// Control
	if(privates.sel.prev !== null) {
		privates.sel.prev.addEventListener('click', () => {
			this.prev_slide();
		});
	}

	if(privates.sel.next !== null) {
		privates.sel.next.addEventListener('click', () => {
			this.next_slide();
		});
	}

}

Методы управления каруселью:

/* Public methods */
// Prev slide
this.prev_slide = () => {
	--privates.opt.position;

	if(privates.opt.position < 0) {
		privates.sel.wrap.classList.add('s-notransition');
		privates.opt.position = privates.opt.max_position - 1;
	}

	privates.sel.wrap.style["transform"] = `translateX(-${privates.opt.position}00%)`;
};


// Next slide
this.next_slide = () => {
	++privates.opt.position;

	if(privates.opt.position >= privates.opt.max_position) {
		privates.opt.position = 0;
	}

	privates.sel.wrap.style["transform"] = `translateX(-${privates.opt.position}00%)`;
};

Методы next_slide и prev_slide будут двигать обертку с помощью transform, дабы не было перерисовки блока, и анимация происходила на GPU.

Делаем карусель:

new Carousel({
	"main": ".js-carousel",
	"wrap": ".js-carousel__wrap",
	"prev": ".js-carousel__prev",
	"next": ".js-carousel__next"
});

Если нужна поддержка IE, то заменяем стрелочную функцию на:
Ну бросьте, все это знают
Если не все знают


Это все! Меньше кода — меньше трафика (jQuery 3.2 ~85kB). Контроль над параметрами и можем использовать несколько раз на странице.

Демо:



Если понравилась статья, то в скором времени будет продолжение с цикличной анимацией, touch-событиями и еще многими вкусными плюшками!
Поделиться с друзьями
-->

Комментарии (18)


  1. forgetable
    24.04.2017 15:24
    #10188718
    +1

    У подобных каруселей всегда хочется, чтобы при переключении с последнего на первый карусель не двигалась назад, а проходила вперёд.


    1. iGetPass
      24.04.2017 15:24
      #10188722
      -1

      Согласен, это будет в следующей статье =)


      1. forgetable
        24.04.2017 15:31
        #10188742
        -1

        Здорово. Большой респект за отсутствие jQuery, кстати


        1. iGetPass
          24.04.2017 15:41
          #10188754
          -1

          Мне тоже нравится, не особо jQuery сегодня в зеленых броузерах нужен и в IE 8+


  1. prgrant
    24.04.2017 16:18
    #10188832
    +2

    Нужен swipe, иначе неактуально


    1. iGetPass
      24.04.2017 16:19
      #10188836
      -1

      Это будет в следующей статье =)


  1. iGetPass
    24.04.2017 16:19
    #10188834
    -1

    Это будет в следующей статье =)


  1. psFitz
    25.04.2017 14:04
    #10190260

    Зачем нам очередные велосипеды? Есть же swiper.


    1. iGetPass
      25.04.2017 17:21
      #10190746
      -1

      Тебе не лень тащить в зависимостях jQuery, который весит 85kB?


      1. psFitz
        26.04.2017 09:17
        #10191396

        Сначала советую разобраться в вопросе, потом умничать, есть много либ без jQuery, так же ничего против jq не имею, если в проекте есть jq — специально ищу либу на нём.
        https://github.com/nolimits4web/Swiper/tree/master/dist/js


        1. iGetPass
          26.04.2017 12:32
          #10191764
          +1

          Ты когда-нибудь сам что-нибудь писал? Или не разбираешься в профессии и постоянно берёшь готовые либы и фреймворки?
          Этот swiper, который без jQ весит 94.2kB в сжатом состоянии. Ты понимаешь сколько человек на плохом интернет соединении будет ждать его подгрузку? Пусть с http/2 && сверхбыстрого CDN && gzip'нутого. Это все время на загрузку и распаковку, когда вместо 94.2 и самого вызова ты можешь написать 5kB, который будет работать, как тебе нужно


          1. psFitz
            27.04.2017 10:17
            #10193472

            Давайте не будем судить кто и как разбирается в профессии, во 1, есть разные сайты и не везде надо писать все свое т.к. время ограничено бюджетом, так что не надо этих розовых мечтаний. Во 2, я уверен, что под конец проекта у вас наберется своих наработок на тех же 94kB, только они не будут протестированы сообществом и скорее всего в них будет куча багов.
            Так же никто не мешает зайти в сорцы и вытащить себе только слайдер.


            1. forgetable
              27.04.2017 10:21
              #10193486

              В этом и суть. Мне кажется, нужно стараться использовать своё и как можно меньше библиотек, если занимаешься серьёзными проектами. Если фрилансить, или поджимает время – для этого есть библиотеки.


            1. iGetPass
              27.04.2017 17:40
              #10194320

              Работай с почасовой оплатой!
              Ты один раз написал хороший модуль, написал тесты к нему, и все. По-хорошему для такого модуля — это часа 2


              1. forgetable
                27.04.2017 18:02
                #10194344

                Я всегда работаю с почасовой оплатой. Да, обычно так и происходит.


                1. iGetPass
                  27.04.2017 18:05
                  #10194350

                  Я про тоже, и клиенту меньше трафика


              1. psFitz
                28.04.2017 09:06
                #10195166

                Что за бред? Клиенту пофиг написал ты свой плагин или взял со стороны, ему главное меньше заплатить, исключением отдельные случаи, да и никто тебе не мешает дернуть сорцы любого плагина и вытащить нужное. Что за собрание анонимных велосипедистов?


                1. iGetPass
                  28.04.2017 13:23
                  #10195824

                  Клиенту нужна большая конверсия, в большинстве. Один из факторов большой конверсии — быстрая загрузка страницы => меньший трафик

МЕТКИ

  • Хабы
  • Теги

JavaScript

Разработка веб-сайтов

javascript

Карусель

СЕРВИСЫ
  • logo

    CloudLogs.ru - Облачное логирование

    • Храните логи вашего сервиса или приложения в облаке. Удобно просматривайте и анализируйте их.
Все публикации автора
  • Карусель на Vanilla.JS. Часть 2 +4

    • 02.05.2017 11:07

    Карусель на Vanilla.JS +11

    • 24.04.2017 11:59

Подписка


ЛУЧШЕЕ

  • Сегодня
  • Вчера
  • Позавчера
05:28

Мне надоело искать ошибки глазами — я создал бесплатный аудитор для 1С +15

08:23

Новая эра: нагрузочное тестирование UI-микросервисов +13

08:02

Включаем EPA в FreeTDS и go-mssqldb: приключение на 5 минут +12

06:40

Как мы сделали автогенерацию документации для CI/CD из комментариев в коде +12

08:01

Короткий промпт ≠ дешёвый промпт: как оптимизация ломает prefix cache в LLM-агентах +11

07:51

Перспективы термоядерных энергетических реакторов: краткий патентный анализ +11

05:07

ИИ-слоп убивает онлайн-сообщества +11

07:00

Видели, как блогеры мажут магазинный чек термозащитой для волос и жарят его плойкой? +10

07:05

Вы неправильно пишете асинхронный Rust: .await там, где его не должно быть +9

07:58

Кто набрал сотни звёзд в Open Source СНГ? И как ваш проект может оказаться следующим +7

07:01

Smart Timber: измеряем лес смартфоном. Часть 2: Технические решения для полевых условий +7

07:42

MFA для VPN в UserGate NGFW: как поднять удаленный доступ для Windows и macOS +6

07:08

В России изготовлен СВЧ-интерферометр для научных экспериментов по измерению плотности плазмы в НИУ «МЭИ» +6

07:04

Кто будет вести секции INFOSTART TECH EVENT 2026 +6

08:00

Celestica DS6000 series: первая ласточка 1,6-терабитных сетей или массовый продукт? +5

07:01

Репортаж с Hi-Tech Building 2026: как выглядит рынок умного дома +5

08:12

Код как документация: как мы строим самодокументируемые витрины данных в Почте Mail +4

08:12

Код как документация: как мы строим самодокументируемые витрины данных в Почте Mail +4

08:00

Короткие видео вместо текстовых комментариев: как я не с того конца тестировал новый формат обратной связи +4

07:26

Автоматизируем посёлок ч. 2: светофор своими руками +4

02:56

Небесная Ось Зла +81

14:18

Локальные LLM в реальной работе: Gemma 4, Qwen 3.6 и Qwen Coder +66

07:16

Как мы автоматизировали свой поселок +64

09:01

Россия выбыла из лунной гонки. Что планируют США и Китай: база, ядерный реактор, спутники слежения +37

07:00

Как технически устроена DPI-фильтрация у российских провайдеров и как её детектировать: разбор open-source инструментов +37

14:05

Bad Apple через CSS: как заставить браузер страдать без единой строчки JavaScript +32

20:17

Как работают с памятью в игровых консолях +29

09:00

Дорожная карта домашнего мини-ПК в 2026: что развернуть, в каком порядке, и зачем — план апгрейда от инфраструктурщика +29

13:01

Лёгкий, доступный, настоящий Телекастер Squier Debut Collection +27

08:00

Как мы в Selectel строим S3-хранилища: от железа до приложения +26

05:02

Хантавирусный круиз у берегов Испании, а также целевая блокировка VPN на 92% +16

13:00

NPU в ноутбуках: что меняется для тех, кто закупает корпоративную технику +15

08:11

Биологи переписали генетический код живой клетки. Что из этого получилось? +13

07:47

Структуры данных на практике. Глава 15: Графы и их обход с эффективным использованием кэша +13

14:44

Найм не спас, Telegram подвёл, ИИ устроил бардак: как мы просели, вернули деньги клиентам, но в итоге собрали веб-сервис +12

08:10

Снимаем показания счётчика воды «Бетар» по RS-485 и «МИР» по BLE с помощью ESP32 +12

12:05

Почему ваш Go‑сервис ломается под 1000 RPS и как найти узкое место за полчаса +11

20:07

Запуск Vivado 2019.1 на Orange Pi 3 LTS  через QEMU +10

02:08

Локальный агент для диагностики инфраструктуры +10

12:39

Коммерческая тайна и промышленный шпионаж: вспоминаем кражу кода у Google +9

13:30

Беспилотные рабочие Чернобыля +71

08:05

Золото демосцены +65

09:01

Электронные лампы — удивительные долгожители +54

13:01

Японцы в ярости от пиратства: как разница в менталитете породила один из самых горячих споров года +38

11:50

How it's made. Карта Морзе +38

06:55

Прочитал свой геном на кухне и превратил мазок щеки в 30 гигабаз данных ДНК +36

08:00

Framework полностью переделала свой модульный ноутбук: что изменилось за 5 лет +35

17:45

Я сделал приложение за вечер без навыков программирования. Фиг там. Как я почти год делал игру с опытом и ИИ +32

08:16

Почему текст от LLM узнаётся за пять секунд: разбираю стилистические маркеры через архитектуру моделей +30

10:09

Я плохой программист, плохой менеджер и вообще недоэксперт в любой области +27

08:59

Как открыть гравитон. Некоторые идеи о квантовании гравитационных волн +21

14:34

В агентскую эпоху не все архитектуры кода одинаково полезны +19

16:05

ИИ-госуслуги в ОАЭ, Claude в Adobe и Ableton, ChatGPT в таблицах и AI Spotify от ElevenLabs +14

12:00

ИИ-серверы Majestic Labs Prometheus: 128 ТБ памяти в одном устройстве, которое заменяет целую стойку +14

14:13

«Эмбеддинги на примерах с собаками», или как работать с векторными представлениями: книги и руководства по теме +13

13:20

Снятся ли искусственному интеллекту цифровые овцы? +12

07:15

Как я спроектировал систему защиты от протечек воды, или аккумулятор с транзистором побеждают бога морей +12

11:30

Тайны трёхцветных кошек +11

07:10

Новая архитектура для агентов: как Intel и SambaNova разделили инференс между GPU, RDU и CPU +11

15:13

Как хранятся большие бинарные данные в БД: накладные расходы BLOB в Oracle и Large Object в Postgres +8

ОБСУЖДАЕМОЕ

  • Почему у синьора 500k, а капитала всё ещё нет -3

    • 232   23000

    Локальные LLM в реальной работе: Gemma 4, Qwen 3.6 и Qwen Coder +66

    • 148   26000

    Рабочая сила стареет и немного про ДМС +1

    • 129   19000

    Как мы автоматизировали свой поселок +64

    • 96   17000

    Дорожная карта домашнего мини-ПК в 2026: что развернуть, в каком порядке, и зачем — план апгрейда от инфраструктурщика +29

    • 90   13000

    Claude Code — полный гайд и обучение для новичков с нуля +7

    • 84   54000

    Как открыть гравитон. Некоторые идеи о квантовании гравитационных волн +21

    • 74   10000

    Как я спроектировал систему защиты от протечек воды, или аккумулятор с транзистором побеждают бога морей +12

    • 74   10000

    Японцы в ярости от пиратства: как разница в менталитете породила один из самых горячих споров года +38

    • 67   15000

    Слова, которых нет +2

    • 58   19000

    Небесная Ось Зла +81

    • 56   16000

    У вас уже есть 48 млн — и вы этого не замечаете -6

    • 45   9600

    Если вы плохо понимаете бесконечности — добро пожаловать в сингулярность +1

    • 39   12000

    Я сделал приложение за вечер без навыков программирования. Фиг там. Как я почти год делал игру с опытом и ИИ +32

    • 36   24000

    ИИ атакует «беловоротничковые» профессии. Чему учить детей? Профессия «на всю жизнь» больше не работает -1

    • 35   8100
  • Главная
  • Контакты
© 2026. Все публикации принадлежат авторам.