Размер шрифта
Цвет фона и шрифта
Изображения
Озвучивание текста
Обычная версия сайта
«8 Ядер» - готовые сайты, интернет-магазины на 1С-Битрикс
Сертифицированный партнёр 1С-Битрикс Аккредитация на портале Госзакупок 44-ФЗ и 223-ФЗ Участник Московского инновационного кластера
+7 906 740 88 03
+7 906 740 88 03
E-mail
customer@8cores.ru
Адрес
г. Москва, ул. Окская, 20к2, пом. 5/1
Режим работы
Пн. – Пт.: с 08:00 до 18:00 (мск)
Продукты
  • Готовые сайты
    • Интернет-магазины
    • Корпоративные сайты
    • Отраслевые сайты
  • Лицензии 1С-Битрикс
  • Продления лицензий
Услуги
  • Разработка сайтов и приложений
    • Запуск сайта на готовом решении 1С-Битрикс
    • Хостинг. Регистрация доменов
    • Разработка сайтов
    • Перенос сайта на 1С-Битрикс
    • Разработка модулей для 1С-Битрикс
    • Лендинг/визитка
  • Интеграция
    • Интеграция сайта с 1С
    • Интеграция с CRM Битрикс24
    • ERP для Производственной компании
    • Интеграция с ФГИС "АРШИН"
    • Интеграция с ФГИС ФСА
  • Поддержка
    • Техническая поддержка
    • Доработка существующего сайта
  • Дизайн
    • Разработка дизайна сайта
  • Информационная безопасность
    • Проверка сайта и удаление вирусов
  • Импорт/Парсинг
Кейсы
  • Разработка сайта
  • Техподдержка сайта
  • Интеграция систем
Блог
Компания
  • О компании
  • Как мы работаем
  • Сертификаты
  • Реквизиты
  • Документы
  • Партнёры
  • Вакансии
Контакты
Москва
«8 Ядер» - готовые сайты, интернет-магазины на 1С-Битрикс
Сертифицированный партнёр 1С-Битрикс Аккредитация на портале Госзакупок 44-ФЗ и 223-ФЗ Участник Московского инновационного кластера
Продукты
  • Готовые сайты
    Готовые сайты
  • Лицензии 1С-Битрикс
    Лицензии 1С-Битрикс
  • Продления лицензий
    Продления лицензий
Услуги
  • Разработка сайтов и приложений
    Разработка сайтов и приложений
  • Интеграция
    Интеграция
  • Поддержка
    Поддержка
  • Дизайн
    Дизайн
  • Информационная безопасность
    Информационная безопасность
  • Импорт/Парсинг
    Импорт/Парсинг
Кейсы
  • Разработка сайта
  • Техподдержка сайта
  • Интеграция систем
Блог
Компания
  • О компании
  • Как мы работаем
  • Сертификаты
  • Реквизиты
  • Документы
  • Партнёры
  • Вакансии
Контакты
    Москва
    +7 906 740 88 03
    +7 906 740 88 03
    E-mail
    customer@8cores.ru
    Адрес
    г. Москва, ул. Окская, 20к2, пом. 5/1
    Режим работы
    Пн. – Пт.: с 08:00 до 18:00 (мск)
    «8 Ядер» - готовые сайты, интернет-магазины на 1С-Битрикс
    Продукты
    • Готовые сайты
      Готовые сайты
    • Лицензии 1С-Битрикс
      Лицензии 1С-Битрикс
    • Продления лицензий
      Продления лицензий
    Услуги
    • Разработка сайтов и приложений
      Разработка сайтов и приложений
    • Интеграция
      Интеграция
    • Поддержка
      Поддержка
    • Дизайн
      Дизайн
    • Информационная безопасность
      Информационная безопасность
    • Импорт/Парсинг
      Импорт/Парсинг
    Кейсы
    • Разработка сайта
    • Техподдержка сайта
    • Интеграция систем
    Блог
    Компания
    • О компании
    • Как мы работаем
    • Сертификаты
    • Реквизиты
    • Документы
    • Партнёры
    • Вакансии
    Контакты
      Москва
      +7 906 740 88 03
      E-mail
      customer@8cores.ru
      Адрес
      г. Москва, ул. Окская, 20к2, пом. 5/1
      Режим работы
      Пн. – Пт.: с 08:00 до 18:00 (мск)
      «8 Ядер» - готовые сайты, интернет-магазины на 1С-Битрикс
      Телефоны
      +7 906 740 88 03
      E-mail
      customer@8cores.ru
      Адрес
      г. Москва, ул. Окская, 20к2, пом. 5/1
      Режим работы
      Пн. – Пт.: с 08:00 до 18:00 (мск)
      «8 Ядер» - готовые сайты, интернет-магазины на 1С-Битрикс
      • Продукты
        • Продукты
        • Готовые сайты
          • Готовые сайты
          • Интернет-магазины
          • Корпоративные сайты
          • Отраслевые сайты
        • Лицензии 1С-Битрикс
        • Продления лицензий
      • Услуги
        • Услуги
        • Разработка сайтов и приложений
          • Разработка сайтов и приложений
          • Запуск сайта на готовом решении 1С-Битрикс
          • Хостинг. Регистрация доменов
          • Разработка сайтов
          • Перенос сайта на 1С-Битрикс
          • Разработка модулей для 1С-Битрикс
          • Лендинг/визитка
        • Интеграция
          • Интеграция
          • Интеграция сайта с 1С
          • Интеграция с CRM Битрикс24
          • ERP для Производственной компании
          • Интеграция с ФГИС "АРШИН"
          • Интеграция с ФГИС ФСА
        • Поддержка
          • Поддержка
          • Техническая поддержка
          • Доработка существующего сайта
        • Дизайн
          • Дизайн
          • Разработка дизайна сайта
        • Информационная безопасность
          • Информационная безопасность
          • Проверка сайта и удаление вирусов
        • Импорт/Парсинг
      • Кейсы
        • Кейсы
        • Разработка сайта
        • Техподдержка сайта
        • Интеграция систем
      • Блог
      • Компания
        • Компания
        • О компании
        • Как мы работаем
        • Сертификаты
        • Реквизиты
        • Документы
        • Партнёры
        • Вакансии
      • Контакты
      • +7 906 740 88 03
        • Телефоны
        • +7 906 740 88 03
      • г. Москва, ул. Окская, 20к2, пом. 5/1
      • customer@8cores.ru
      • Пн. – Пт.: с 08:00 до 18:00 (мск)
      Сертифицированный партнёр 1С-Битрикс Аккредитация на портале Госзакупок 44-ФЗ и 223-ФЗ Участник Московского инновационного кластера
      Главная
      —
      Блог
      —
      jQuery
      —Слайдер-превью изображений при наведении мыши

      Слайдер-превью изображений при наведении мыши

      слайдер-превью изображений при наведении мыши
      jQuery
      18 сентября 2024

      На сайтах интернет-магазинов (или тому подобных), где на страницах рубрик представлены карточки товаров или услуг, можно встретить мини-слайдеры, в которых показаны превью этих товаров и услуг. При наведении курсора и перемещении его влево-вправо можно посмотреть несколько таких изображений. Чтобы было более понятно, о чем идет речь, зайдите на сайты ozon.ru или realty.yandex.ru.

      Реализация функционала этого слайдера в двух вариантах: на jQuery и в нативном JavaScript.

      Из особенностей: на десктопе изображения меняются при перемещении курсора мыши над ним горизонтально, а на мобильных устройствах – если проводить пальцем по изображению.

      Исходная структура HTML-кода

      <div class="images">
        <img src="image">
        <img src="image">
        <img src="image">
      </div>
      После выполнения скрипта она обретает следующий вид:

      <div class="hvr">
        <div class="hvr__images">
          <div class="images">
            <img class="image">
            <img class="image">
            <img class="image">
          </div>
          <div class="hvr__sectors">
            <div class="hvr__sector"></div>
            <div class="hvr__sector"></div>
            <div class="hvr__sector"></div>
          </div>
        </div>
        <div class="hvr__dots">
          <div class="hvr__dot hvr__dot--active"></div>
          <div class="hvr__dot"></div>
          <div class="hvr__dot"></div>
        </div>
      </div>

      CSS-код

      Есть обязательные стили:

      .hvr__images {
        position: relative;
      }
      
      .hvr__sectors {
        position: absolute;
        top: 0;
        left: 0;
        right: 0;
        bottom: 0;
        display: flex;
      }
      
      .hvr__sector {
        flex-grow: 1;
      }

      Также можно добавить дополнительные стили:

      • для изображений, чтобы до срабатывания скрипта отображалось только первое изображение;
      • для точек, показывающих общее количество изображений и активный слайд.
      .images {
        display: flex;
        overflow: hidden;
      }
      
      .image {
        display: block;
      }
      
      .hvr__dots {
        display: flex;
        align-items: center;
        justify-content: center;
      }
      
      .hvr__dot {
        width: 5px;
        height: 5px;
        margin: 10px 2px 0;
        border-radius: 50%;
        background: #d6dbe0;
      }
      
      .hvr__dot--active {
        background: #000;
      }

      Решение на jQuery

      (function ($) {
        $.fn.HvrSlider = function () {
          return this.each(function () {
            var el = $(this);
            if (el.find('img').length > 1) {
              var hvr = $('<div>', {
                class: 'hvr',
                append: [
                  $('<div>', {
                    class: 'hvr__images',
                    append: $('<div>', {
                      class: 'hvr__sectors',
                    }),
                  }),
                  $('<div>', {
                    class: 'hvr__dots',
                  }),
                ],
                insertAfter: el,
                prepend: el,
              });
              var hvrImages = $('.hvr__images', hvr);
              var hvrImage = $('img', hvr);
              var hvrSectors = $('.hvr__sectors', hvr);
              var hvrDots = $('.hvr__dots', hvr);
              el.prependTo(hvrImages);
              hvrImage.each(function () {
                hvrSectors.prepend('<div class="hvr__sector"></div>');
                hvrDots.append('<div class="hvr__dot"></div>');
              });
              $('.hvr__dot:first', hvrDots).addClass('hvr__dot--active');
              var setActiveEl = function (el) {
                hvrImage.hide().eq(el.index()).show();
                $('.hvr__dot', hvrDots).removeClass('hvr__dot--active').eq(el.index()).addClass('hvr__dot--active');
              };
              $('.hvr__sector', hvrSectors).hover(function () {
                setActiveEl($(this));
              });
              hvrSectors.on('touchmove', function (e) {
                var position = e.originalEvent.changedTouches[0];
                var target = document.elementFromPoint(position.clientX, position.clientY);
                if ($(target).is('.hvr__sector')) {
                  setActiveEl($(target));
                }
              });
            }
          });
        };
      })(jQuery);

      Код для инициализации скрипта:

      $('.images').HvrSlider();

      Решение на JavaScript

      class HvrSlider {
        constructor(selector) {
          const elements = document.querySelectorAll(selector);
          elements.forEach((el) => {
            if (el.querySelectorAll('img').length > 1) {
              const hvr = document.createElement('div');
              hvr.classList.add('hvr');
      
              const hvrImages = document.createElement('div');
              hvrImages.classList.add('hvr__images');
              hvr.appendChild(hvrImages);
      
              const hvrSectors = document.createElement('div');
              hvrSectors.classList.add('hvr__sectors');
              hvrImages.appendChild(hvrSectors);
      
              const hvrDots = document.createElement('div');
              hvrDots.classList.add('hvr__dots');
              hvr.appendChild(hvrDots);
      
              el.parentNode.insertBefore(hvr, el);
              hvrImages.prepend(el);
      
              const hvrImagesArray = hvr.querySelectorAll('img');
              hvrImagesArray.forEach(() => {
                hvrSectors.insertAdjacentHTML('afterbegin', '<div class="hvr__sector"></div>');
                hvrDots.insertAdjacentHTML('afterbegin', '<div class="hvr__dot"></div>');
              });
              hvrDots.firstChild.classList.add('hvr__dot--active');
              const setActiveEl = function (targetEl) {
                const index = [...hvrSectors.children].indexOf(targetEl);
                hvrImagesArray.forEach((img, idx) => {
                  if (index == idx) {
                    img.style.display = 'block';
                  } else {
                    img.style.display = 'none';
                  }
                });
                hvr.querySelectorAll('.hvr__dot').forEach((dot, idx) => {
                  if (index == idx) {
                    dot.classList.add('hvr__dot--active');
                  } else {
                    dot.classList.remove('hvr__dot--active');
                  }
                });
              };
              hvrSectors.addEventListener('mouseover', function (e) {
                if (e.target.matches('.hvr__sector')) {
                  setActiveEl(e.target);
                }
              });
              hvrSectors.addEventListener('touchmove', function (e) {
                const position = e.changedTouches[0];
                const target = document.elementFromPoint(position.clientX, position.clientY);
                if (target.matches('.hvr__sector')) {
                  setActiveEl(target);
                }
              });
            }
          });
        }
      }

      Код для инициализации скрипта:

      new HvrSlider('.images');
      • Комментарии
      Загрузка комментариев...
      Назад к списку
      • 1С Администрирование 2
      • 1С-Битрикс 30
      • HTML/CSS 1
      • jQuery 2
      • PHP 2
      • Оптимизация 9
      1с 1С ajax apache api bitrix clean-param CRM cron curl etext get google htaccess html jivo jquery json market marketplace nginx openserver PageSpeed php php8 post robots robots.txt search seo web агенты администрирование артикул аспро битрикс боты вирус директория защита каталог композит кэш логи магазин маркетплейс метрика модальные окна настройка обмен онлайн консультант оптимизация ордер ошибки пагинация папка парсинг поиск покупка сервера склад скрипт спам страница тестирование троян ускорение установка ут цвета чпу юkassa яндекс
      Продукты
      Услуги
      Компания
      Блог
      Контакты
      Сертифицированный партнёр 1С-Битрикс Аккредитация на портале Госзакупок 44-ФЗ и 223-ФЗ Участник Московского инновационного кластера
      +7 906 740 88 03
      +7 906 740 88 03
      E-mail
      customer@8cores.ru
      Адрес
      г. Москва, ул. Окская, 20к2, пом. 5/1
      Режим работы
      Пн. – Пт.: с 08:00 до 18:00 (мск)
      customer@8cores.ru
      г. Москва, ул. Окская, 20к2, пом. 5/1
      © 2010-2025 «8 Ядер» - веб-студия полного цикла
      Политика конфиденциальности
      Разработано в