Как создать плагин слайд шоу на 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-11-26 » Капитан грузового судна, или Как начать использовать Docker в своих проектах
- 2024-11-26 » Обеспечение безопасности ваших веб-приложений с помощью PHP OOP и PDO
- 2024-11-22 » Ошибки в Яндекс Вебмастере: как найти и исправить
- 2024-11-22 » Ошибки в Яндекс Вебмастере: как найти и исправить
- 2024-11-15 » Перенос сайта на WordPress с одного домена на другой
- 2024-11-08 » OSPanel 6: быстрый старт
- 2024-11-08 » Как установить PhpMyAdmin в Open Server Panel
- 2024-09-30 » Как быстро запустить Laravel на Windows
- 2024-09-25 » Next.js
- 2024-09-05 » OpenAI рассказал, как запретить ChatGPT использовать содержимое сайта для обучения
- 2024-08-28 » Чек-лист: как увеличить конверсию интернет-магазина на примере спортпита
- 2024-08-01 » WebSocket
- 2024-07-26 » Интеграция с Яндекс Еда
- 2024-07-26 » Интеграция с Эквайринг
- 2024-07-26 » Интеграция с СДЕК
- 2024-07-26 » Интеграция с Битрикс-24
- 2024-07-26 » Интеграция с Travelline
- 2024-07-26 » Интеграция с Iiko
- 2024-07-26 » Интеграция с Delivery Club
- 2024-07-26 » Интеграция с CRM
- 2024-07-26 » Интеграция с 1C-Бухгалтерия
- 2024-07-24 » Что такое сторителлинг: техники и примеры
- 2024-07-17 » Ошибка 404: что это такое и как ее использовать для бизнеса
- 2024-07-03 » Размещайте прайс-листы на FarPost.ru и продавайте товары быстро и выгодно
- 2024-07-01 » Профилирование кода в PHP
- 2024-06-28 » Изучаем ABC/XYZ-анализ: что это такое и какие решения с помощью него принимают
- 2024-06-17 » Зачем вам знать потребности клиента
- 2024-06-11 » Что нового в работе Яндекс Метрики: полный обзор обновления
- 2024-06-11 » Поведенческие факторы ранжирования в Яндексе
- 2024-06-11 » Скорость загрузки сайта: почему это важно и как влияет на ранжирование
Всегда храни верность своему начальнику - следующий, может быть еще хуже... |
Мы создаем сайты, которые работают! Профессионально обслуживаем и продвигаем их , а также по всей России и ближнему зарубежью с 2006 года!
Как мы работаем
Заявка
Позвоните или оставьте заявку на сайте.
Консультация
Обсуждаем что именно Вам нужно и помогаем определить как это лучше сделать!
Договор
Заключаем договор на оказание услуг, в котором прописаны условия и обязанности обеих сторон.
Выполнение работ
Непосредственно оказание требующихся услуг и работ по вашему заданию.
Поддержка
Сдача выполненых работ, последующие корректировки и поддержка при необходимости.