Как создать плагин слайд шоу на 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
|
Существуют сотни плагинов слайдшоу, от популярного Lightbox до продвинутого Galleria. Зачем создавать еще один? Наверняка вы используете подобный плагин на своем веб сайте. Неужели не интересно, как |
РэдЛайн, создание сайта, заказать сайт, разработка сайтов, реклама в Интернете, продвижение, маркетинговые исследования, дизайн студия, веб дизайн, раскрутка сайта, создать сайт компании, сделать сайт, создание сайтов, изготовление сайта, обслуживание сайтов, изготовление сайтов, заказать интернет сайт, создать сайт, изготовить сайт, разработка сайта, web студия, создание веб сайта, поддержка сайта, сайт на заказ, сопровождение сайта, дизайн сайта, сайт под ключ, заказ сайта, реклама сайта, хостинг, регистрация доменов, хабаровск, краснодар, москва, комсомольск |
Дайджест новых статей по интернет-маркетингу на ваш email
Новые статьи и публикации
- 2025-12-02 » Когда ошибка молчит: как бессмысленные сообщения ломают пользовательский опыт
- 2025-12-02 » 9 лучших бесплатных фотостоков
- 2025-12-02 » UTM-метки: ключевой инструмент аналитики для маркетолога
- 2025-12-02 » ПромоСтраницы Яндекса: Что такое и для чего служит
- 2025-12-02 » Метатеги для сайта: исчерпывающее руководство по Title, Description, Canonical, Robots и другим тегам
- 2025-11-26 » Оценка эффективности контента: превращаем информационный балласт в рабочий актив
- 2025-11-26 » 10 причин высокого показателя отказов на сайте
- 2025-11-26 » Когда и зачем обновлять структуру сайта
- 2025-11-26 » Скрытые демотиваторы: как мелочи разрушают эффективность команды
- 2025-11-26 » Зачем запускать MVP и как сделать это грамотно?
- 2025-11-20 » Половина российских компаний сократит расходы на транспорт и маркетинг в 2026 году
- 2025-11-20 » Перенос сайта с большим количеством ссылок
- 2025-11-20 » Перелинковка сайта: Что такое и как ее использовать
- 2025-11-20 » Критерии выбора SEO-специалиста и подрядчика для продвижения сайта
- 2025-11-20 » Применение искусственного интеллекта в рекламных агентствах: комплексное исследование трендов 2025 года
- 2025-11-19 » Геозапросы по-новому: как покорить локальное SEO с помощью ИИ
- 2025-11-14 » Консалтинг: сущность и ключевые направления
- 2025-11-14 » Онлайн-формы: универсальный инструмент для сбора обратной связи
- 2025-11-14 » Факторы конверсии органического трафика
- 2025-11-14 » Планирование рекламного бюджета: самостоятельный подход
- 2025-11-14 » Авторизация на сайте: как выбрать решение для удержания клиентов и сохранения продаж
- 2025-11-13 » Эффективные методы стимулирования клиентов к оставлению положительных отзывов
- 2025-11-13 » Налоговая реформа — 2026: грядущие изменения для предпринимателей
- 2025-11-13 » Альтернативы мессенджерам: что выбрать вместо Telegram и WhatsApp
- 2025-11-13 » Маркировка рекламы для начинающих: полное руководство по требованиям ЕРИР
- 2025-11-13 » ИИ не отберет вашу работу — её займет специалист, владеющий искусственным интеллектом
- 2025-10-29 » Как оценить эффективность работы SEO-специалиста: практическое руководство для маркетологов и владельцев бизнеса
- 2025-10-29 » Киберспорт как маркетинговый инструмент: стратегии привлечения геймеров
- 2025-10-29 » Как говорить с аудиторией о сложном
- 2025-10-29 » Что такое доказательства с нулевым разглашением (ZKP) и их роль в блокчейне
Гораздо больше людей сдавшихся, чем побежденных. |
Мы создаем сайты, которые работают! Профессионально обслуживаем и продвигаем их , а также по всей России и ближнему зарубежью с 2006 года!
Как мы работаем
Заявка
Позвоните или оставьте заявку на сайте.
Консультация
Обсуждаем что именно Вам нужно и помогаем определить как это лучше сделать!
Договор
Заключаем договор на оказание услуг, в котором прописаны условия и обязанности обеих сторон.
Выполнение работ
Непосредственно оказание требующихся услуг и работ по вашему заданию.
Поддержка
Сдача выполненых работ, последующие корректировки и поддержка при необходимости.


Мы создаем практически любые сайты от продающих страниц до сложных, высоконагруженных и нестандартных веб приложений! Наши сайты это надежные маркетинговые инструменты для успеха Вашего бизнеса и увеличения вашей прибыли! Мы делаем красивые и максимально эффектные сайты по доступным ценам уже много лет!
Комплексный подход это не просто продвижение сайта, это целый комплекс мероприятий, который определяется целями и задачами поставленными перед сайтом и организацией, которая за этим стоит. Время однобоких методов в продвижении сайтов уже прошло, конкуренция слишком высока, чтобы была возможность расслабиться и получать \ удерживать клиентов из Интернета, просто сделав сайт и не занимаясь им...
Мы оказываем полный комплекс услуг по сопровождению сайта: информационному и техническому обслуживанию и развитию Интернет сайтов.
Контекстная реклама - это эффективный инструмент в интернет маркетинге, целью которого является увеличение продаж. Главный плюс контекстной рекламы заключается в том, что она работает избирательно.