Как создать плагин слайд шоу на jQuery
Существуют сотни плагинов слайдшоу, от популярного Lightbox до продвинутого Galleria. Зачем создавать еще один? Наверняка вы используете подобный плагин на своем веб сайте. Неужели не интересно, как самому сделать такой замечательный инструмент. А свой код гораздо проще модифицировать и добавлять особенные фишки, если вдруг захочется развивать проект.
Введение
Если вы часто пользуетесь плагинами слайдшоу, то наверняка заметили, что они делятся на две категории. Первая использует проскальзывание для смены слайдов, а во второй применяются различные эффекты. В зависимости от типа смены слайдов будет меняться подход к кодированию плагина.
В нашем примере используется подход, основанный на использовании эффекта затухания. Чтобы его реализовать вам потребуются базовые знания HTML, CSS и jQuery.
Структура проекта
Файлы для нашего проекта располагаются в определённой структуре каталогов, которая представлена на рисунке:
960gs и modernizr не являются необходимыми для проекта, но очень полезны. Отдельный файл стилей для IE останется пустым, но он может понадобиться вам, если вы решите развивать проект дальше.
Основы слайдера
Начнем построение нашего слайдера.
Сначала определим структуру разметки HTML для слайдшоу в файле index.html
:
<div id="slider"> <img src="/lessons/les1219/img/img1.jpg" title="Название для 1-й картинки" /> <img src="/lessons/les1219/img/img2.jpg" title="Название для 2-й картинки" /> <img src="/lessons/les1219/img/img3.jpg" title="Название для 3-й картинки" /> </div>
Также сделаем вызов плагина jQuery после загрузки документа. Код разместим в файле js/scripts.js
:
$(function(){ $('#slider').powerSlide(); });
База для создания плагина создана. Можно приступать к кодированию.
Посмотрим на структуру кода HTML, которая будет нужна для работы плагина:
То есть наш код jQuery должен генерировать следующий код HTML в оригинальной структуре DOM:
<div class="powerSlide"> <div class="wrapper"> <a href="/" class="prev"></a> <a href="/" class="next"></a> <div class="image"> <img src="/" alt="" /> <p></p> </div> </div> <div class="nav"></div> </div>
Открываем файл js/powerSlide.js
и пишем в него код:
(function($){ $.fn.powerSlide = function(options { var opt = { // Опции }; return this.each(function() { if (options) { $.extend(opt, options); } /* Код плагина будет здесь */ }); }; })(jQuery);
Опции - это переменные, которые мы можем задавать при вызове плагина для управления его действиями. Опции обычно имеют значения по умолчанию, которые изменяются заданными при вызове величинами:
'width': 908, // Высота и ширина изображений 'height': 340, 'position': 'bottom', // Положение навигации 'bullets': false, // Выводить цифровую навигацию 'thumbs': true, // Выводить навигацию миниатюрами 'row': 10, // Миниатюр на строке 'auto': true, // Автопроигрывание 'autoSpeed': 4000, // Скорость смены слайдов при автопроигрывании 'fadeSpeed': 1000 //скорость затухания слайда при смене
Теперь мы можем использовать опции в коде с помощью структуры opt.опция
. Например, для использования значения ширины пишем opt.width
.
В цикле “each” создаем элементы для нашей структуры HTML кода слайдера. И присваиваем их переменным, чтобы легко и быстро получить к ним доступ в коде позже.
/* Контейнер -----------------------------------------------*/ $(this).children().wrapAll('<div class="powerSlide" />'); var container = $(this).find('.powerSlide'); container.find('img').wrapAll('<div class="wrapper" />'); var wrapper = container.find('.wrapper'); /* Кнопки "предыдущий" и "следующий" -----------------------------------------------*/ wrapper.append('<a href="#" class="prev"><<</a><a href="#" class="next">>></a>'); /* Навигация и названия -----------------------------------------------*/ switch (opt.position) { // Положение навигации case 'top': container.prepend('<div class="nav" />'); break; case 'bottom': container.append('<div class="nav" />'); break; } var nav = container.find('.nav'); wrapper.find('img').each(function(i){ i += 1; // Start numbers at 1 if (opt.bullets === true) { // Кнопочная навигация nav.append('<a href="#">'+ i +'</a>'); } if (opt.thumbs === true) { // Навигация миниатюрами nav.addClass('thumbs').append( '<img class="thumb" src="'+ $(this).attr('src') +'" alt=""/>'); } // Названия var title = $(this).attr('title'); $(this).wrapAll('<div class="image" />'); if (title !== undefined) { $(this).attr('title', ''); $(this).after('<p>'+ title +'</p>'); } });
Теперь наши элементы созданы, и можно погрузиться в CSS.
Мы создадим отдельный файл темы для всех настроек цветов и изяществ CSS3. Такой ход поможет нам сохранить код в чистоте и упростить процесс создания новой темы.
Открываем css/powerSlide.css
и пишем в него код:
/* Контейнер -------------------------------------------*/ .powerSlide .wrapper { overflow: hidden; padding: 15px; position: relative; } /* Изображение -------------------------------------------*/ .powerSlide .wrapper img { position: absolute; /* They key to the “effects” approach */ } /* Кнопки "предыдущий" и "следующий" -------------------------------------------*/ .powerSlide a.prev, .powerSlide a.next { display: none; margin-top: -1em; padding: 1em 2em; position: absolute; text-decoration: none; top: 50%; } .powerSlide a.next { right: 0; } /* Название -------------------------------------------*/ .powerSlide .wrapper p { bottom: 0; display: none; padding: 1.5em; position: absolute; } /* Навигация -------------------------------------------*/ .powerSlide .nav { margin: .5em 0; overflow: hidden; } .powerSlide .nav.thumbs { padding: 15px; } .powerSlide .nav img.thumb { cursor: pointer; float: left; margin: 2px; position: relative; } .powerSlide .nav img.thumb.current { /* Текущая миниатюра */ z-index: 999; } .powerSlide .nav a { float:left; margin: .2em; min-width: 1em; padding: .2em .7em; text-align: center; text-decoration: none; } .powerSlide .nav a.current {} /* Текущая кнопка */
Код CSS достаточно простой. Элементы внутри контейнера имеют абсолютное позиционирование. Также нужно быть осторожным с полями и отступами. Размеры будут генерироваться позже в коде jQuery.
Объект Slider
Для хранения информации и действий слайдера мы будем использовать объект. Самая важная концепция слайдера - индекс. Нам нужно знать индекс любого заданного изображения в любое время. Индекс позволяет управлять выводом нужного изображения при генерации события.
Ниже приводятся список всех свойств и методов объекта и их краткое описание:
- imgs: селектор для всех изображений;
- imgCount: количество выбранных изображений;
- navNext: кнопка "следующий";
- navPrev: кнопка "предыдущий";
- bullets: селектор всех кнопок навигации;
- thumbs: селектор всех миниатюр навигации;
- captions: селектор всех названий;
- getCurrentIndex(): получаем индекс текущего изображения в любое время;
- go(index): переход к изображению с заданным индексом;
- next(): переход к следующему изображению;
- prev(): переход к предыдущему изображению;
- init(): устанавливаем высоту и ширину слайдшоу и вычисляем размеры динамических элементов.
/* Объект Slider -----------------------------------------------*/ var Slider = function(){ this.imgs = wrapper.find('div.image'); this.imgCount = (this.imgs.length) - 1; // Индекс соответствия this.navPrev = wrapper.find('a.prev'); this.navNext = wrapper.find('a.next'); this.bullets = container.find('.nav a'); this.thumbs = container.find('.nav img.thumb'); this.captions = this.imgs.find('p'); this.getCurrentIndex = function(){ // Индекс return this.imgs.filter('.current').index(); }; this.go = function(index){ // Смена изображений this.imgs .removeClass('current') .fadeOut(opt.fadeSpeed) .eq(index) .fadeIn(opt.fadeSpeed) .addClass('current'); this.bullets .removeClass('current') .eq(index) .addClass('current'); this.thumbs .removeClass('current') .eq(index) .addClass('current'); }; this.next = function(){ var index = this.getCurrentIndex(); if (index < this.imgCount) { this.go(index + 1); // Переходим к следующему } else { this.go(0); // Если последнее - то переходим к первому } }; this.prev = function(){ var index = this.getCurrentIndex(); if (index > 0) { this.go(index - 1); // Переходим к предыдущему } else { this.go(this.imgCount); // Если первое, то переходим к последнему } }; this.init = function(){ // Init wrapper .width(opt.width) .height(opt.height); /* Устанавливаем высоту и ширину */ this.imgs.hide().first().addClass('current').show(); /* Устанавливаем текущее изображение */ this.bullets.first().addClass('current'); this.thumbs.first().addClass('current'); // Размеры для миниатюр и названий var padding = wrapper.css('padding-left').replace('px', ''); var captionsPadding = this.captions.css('padding-left').replace('px', ''); nav.width(opt.width); if (opt.thumbs === true) { // Миниатюры var thumbBorder = this.thumbs.css('border-left-width').replace('px', ''); var thumbMargin = this.thumbs.css('margin-right').replace('px', ''); var thumbMaxWidth = opt.width/opt.row; this.thumbs.width( (thumbMaxWidth - (thumbMargin * 2)) - (thumbBorder * 2) ); } this.captions // Названия .width(opt.width - (captionsPadding * 2) + 'px') .css('margin-bottom', padding + 'px'); this.navNext.css('margin-right', padding + 'px'); }; };
Теперь объект определен, и мы можем создать новый экземпляр и загрузить его с помощью функции init()
.
var slider = new Slider(); slider.init();
События мыши
Мы хотим обрабатывать следующие события:
- Нажатия на кнопке "следующий" с переходом к следующему изображению.
- Нажатия на кнопке "предыдущий" с переходом к предыдущему изображению.
- Нажатие на кнопке навигации с переходом к соответствующему изображению.
- Нажатие на миниатюре с переходом к соответствующему изображению.
- Наведение курсора мыши на изображение с выводом названия и кнопок.
Нужно отключить реакцию на нажатие ссылки по умолчанию с помощью e.preventDefault(),
чтобы избежать переключения наверх страницы. Также мы скрываем название изображения.
wrapper.hover(function(){ // Курсор над контейнером slider.captions.stop(true, true).fadeToggle(); slider.navNext.stop(true, true).fadeToggle(); slider.navPrev.stop(true, true).fadeToggle(); }); slider.navNext.click(function(e){ // Нажатие на кнопку "следующий" e.preventDefault(); slider.next(); }); slider.navPrev.click(function(e){ // Нажатие на кнопку "предыдущий" e.preventDefault(); slider.prev(); }); slider.bullets.click(function(e){ // Нажатие на кнопку цифровой навигации e.preventDefault(); slider.captions.hide(); slider.go($(this).index()); }); slider.thumbs.click(function(){ // Нажатие на миниатюру slider.captions.hide(); slider.go($(this).index()); });
Автопроигрывание
if (opt.auto === true) { var timer = function(){ slider.next(); slider.captions.hide(); }; var interval = setInterval(timer, opt.autoSpeed); // Пауза при наведении курсора мыши на изображение wrapper.hover(function(){clearInterval(interval);}, function(){interval=setInterval(timer, opt.autoSpeed);}); // Сбрасываем таймер, когда нажата миниатюра или кнопка slider.thumbs.click(function(){clearInterval(interval); interval=setInterval(timer, opt.autoSpeed);}); slider.bullets.click(function(){clearInterval(interval); interval=setInterval(timer, opt.autoSpeed);}); }
Создаем тему
Плагин уже работает. Осталось улучшить его внешний вид.
Создаем файл css/powerSlide_theme.css
и включаем его в index.html
.
И создаем в нем код CSS:
/* Контейнер -------------------------------------------*/ .powerSlide .wrapper { background:#fff; border:1px solid #999; } /* Кнопки "следуюший" и "предыдущий" -------------------------------------------*/ .powerSlide a.prev, .powerSlide a.next { background:#fff; box-shadow:2px 0 2px rgba(0,0,0,.3); color:#000; font:bold 10px Arial; } .powerSlide a.next { box-shadow:-2px 0 2px rgba(0,0,0,.3); } /* Название -------------------------------------------*/ .powerSlide .wrapper p { background:#000; background:rgba(0,0,0,.7); color:#fff; } /* Навигация -------------------------------------------*/ .powerSlide .nav.thumbs { background:#b5bdc8; border:1px solid #999; } .powerSlide .nav img.thumb { margin: 3px; box-shadow:0 0 2px #666; border: 4px solid transparent; filter:alpha(opacity=40); opacity:.4; } .powerSlide .nav a { background:#7d7e7d; background:-moz-linear-gradient(top, #7d7e7d 0%, #0e0e0e 100%); background:-webkit-gradient(linear, left top, left bottom, color-stop(0%,#7d7e7d), color-stop(100%,#0e0e0e)); background:-webkit-linear-gradient(top,#7d7e7d0%,#0e0e0e100%); background:-o-linear-gradient(top,#7d7e7d0%,#0e0e0e100%); background:-ms-linear-gradient(top,#7d7e7d0%,#0e0e0e100%); background:linear-gradient(top,#7d7e7d0%,#0e0e0e100%); border-radius:3px; color:#fff; filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#7d7e7d',endColorstr='#0e0e0e',GradientType=0); font:bold 12px Arial; } .powerSlide .nav img.thumb.current { box-shadow:0 0 10px #fff; border: 4px solid #fff; filter:alpha(opacity=100); opacity:1; } .powerSlide .nav a.current { background:#1e5799; background:-moz-linear-gradient(top, #1e5799 0%, #2989d8 50%, #207cca 51%, #7db9e8 100%); background:-webkit-gradient(linear, left top, left bottom, color-stop(0%,#1e5799), color-stop(50%,#2989d8), color-stop(51%,#207cca), color-stop(100%,#7db9e8)); background:-webkit-linear-gradient(top,#1e57990%,#2989d850%,#207cca51%,#7db9e8100%); background:-o-linear-gradient(top,#1e57990%,#2989d850%,#207cca51%,#7db9e8100%); background:-ms-linear-gradient(top,#1e57990%,#2989d850%,#207cca51%,#7db9e8100%); background:linear-gradient(top,#1e57990%,#2989d850%,#207cca51%,#7db9e8100%); filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#1E5799',endColorstr='#7db9e8',GradientType=0); }
Готово!
Источник: http://feedproxy.google.com/~r/ruseller/CdHX/~3/kC8-qyy8fvw/lessons.php
Дайджест новых статей по интернет-маркетингу на ваш email
Новые статьи и публикации
- 2024-04-17 » 23 сервиса для эффективного экспресс-аудита любого сайта
- 2024-04-08 » Яндекс переходит на новую версию Wordstat
- 2024-04-08 » Яндекс интегрировал в свой облачный сервис эмпатичную нейросеть
- 2024-04-08 » Новая версия нейросети Claude превзошла по мощности аналоги Google и OpenAI
- 2024-04-08 » Как пользоваться GPT 4 и Claude бесплатно и без VPN
- 2024-03-13 » Стратегии SEO на 2024 год
- 2024-03-13 » Как использовать анимацию с помощью JavaScript-библиотеки GSAP
- 2024-03-13 » Использование GSAP 3 для веб-анимации
- 2024-03-13 » Cогласование топографической съёмки с эксплуатирующими организациями
- 2024-02-19 » Теряются лиды? Как настроить сквозную аналитику
- 2024-02-17 » Мерч и IT: на что обратить внимание в 2024 году
- 2024-02-16 » Копируем с RSync: основные примеры синхронизации файлов
- 2024-02-15 » Лучшие noCode AI платформы для создания диалоговых ботов
- 2024-02-14 » Факторы ранжирования Google 2024 — исследование Semrush
- 2024-02-12 » Перенос сайта на другой хостинг
- 2024-02-05 » В России сформирован реестр хостинг-провайдеров
- 2024-02-04 » Использование SSH для подключения к удаленному серверу Ubuntu
- 2024-02-03 » Подключаемся к серверу за NAT при помощи туннеля SSH. Простая и понятная инструкция
- 2024-02-02 » Настройка CI/CD для Gitlab-репозитория: схемы и гайд по шагам
- 2024-02-01 » GitLab CI Pipeline. Запуск сценария через SSH на удаленном сервере
- 2024-01-29 » Introduction to GitLab’s CI/CD for Continuous Deployments
- 2024-01-26 » Настройка GitLab CI/CD
- 2024-01-25 » Установка shell gitlab runner
- 2024-01-25 » Установка и регистрация gitlab-runner в docker контейнере
- 2024-01-25 » Переменные Gitlab-Ci
- 2024-01-25 » Настройка CI/CD в GitLab для синхронизации проекта с веб-серверами
- 2024-01-25 » Копирование файлов scp
- 2024-01-21 » Бездепозитные бонусы от казино: обзор условий и правил использования
- 2024-01-18 » Современная обработка ошибок в PHP
- 2024-01-18 » Пример шаблона проектирования MVC в PHP
Каждый человек имеет право на собственное мнение — при условии, что оно совпадает с нашим Шоу Джордж Бернард - 1856-1950) - английский писатель. В своем творчестве ниспровергал догматизм и предвзятость, традиционность представлений |
Мы создаем сайты, которые работают! Профессионально обслуживаем и продвигаем их , а также по всей России и ближнему зарубежью с 2006 года!
Как мы работаем
Заявка
Позвоните или оставьте заявку на сайте.
Консультация
Обсуждаем что именно Вам нужно и помогаем определить как это лучше сделать!
Договор
Заключаем договор на оказание услуг, в котором прописаны условия и обязанности обеих сторон.
Выполнение работ
Непосредственно оказание требующихся услуг и работ по вашему заданию.
Поддержка
Сдача выполненых работ, последующие корректировки и поддержка при необходимости.