Меню с изображениями на jQuery
В данном уроке мы сделаем простое и эффектное меню на jQuery с использованием изображений. Пункты меню будут оформлены в виде слайдов, которые будут отодвигаться при наведении курсора мыши.
Первый вариант
Разметка HTML
Структура меню будет построена на основании неупорядоченного списка:
<div class="jimgMenu"> <ul> <li class="landscapes"><a href="#nogo">Ландшафты</a></li> <li class="people"><a href="#nogo">Люди</a></li> <li class="nature"><a href="#nogo">Природа</a></li> <li class="abstract"><a href="#nogo">Абстракция</a></li> <li class="urban"><a href="#nogo">Город</a></li> </ul> </div>
CSS
.jimgMenu { position: relative; width: 670px; height: 200px; overflow: hidden; margin: 25px 0px 0px; } .jimgMenu ul { list-style: none; margin: 0px; display: block; height: 200px; width: 1340px; } .jimgMenu ul li { float: left; } .jimgMenu ul li a { text-indent: -1000px; background:#FFFFFF none repeat scroll 0%; border-right: 2px solid #fff; cursor:pointer; display:block; overflow:hidden; width:78px; height: 200px; } .jimgMenu ul li.landscapes a { background: url(images/landscapes.jpg) repeat scroll 0%; } .jimgMenu ul li.people a { background: url(images/people.jpg) repeat scroll 0%; } .jimgMenu ul li.nature a { background: url(images/nature.jpg) repeat scroll 0%; } .jimgMenu ul li.abstract a { background: url(images/abstract.jpg) repeat scroll 0%; } .jimgMenu ul li.urban a { background: url(images/urban.jpg) repeat scroll 0%; min-width:310px; }
JavaScript
В раздел head страницы нужно включить jQuery и все плагины, необходимые для работы меню:
<link href="/css/jimgMenu.css" rel="stylesheet" type="text/css" /> <script type="text/javascript" src="/js/jquery.js"></script> <script type="text/javascript" src="/js/jquery-easing-1.3.pack.js"></script> <script type="text/javascript" src="/js/jquery-easing-compatibility.1.2.pack.js"></script>
А затем добавить код для активации нашего меню:
<script type="text/javascript"> $(document).ready(function () { // Находим элементы для меню и устанавливаем для них обработчик события $('div.jimgMenu ul li a').hover(function() { // Если элемент анимируется в текущий момент if ($(this).is(':animated')) { $(this).stop().animate({width: "310px"}, {duration: 450, easing:"easeOutQuad"}); } else { // Раскрываем элемент $(this).stop().animate({width: "310px"}, {duration: 400, easing:"easeOutQuad"}); } }, function () { // При наведении курсора мыши в другое место, сворачиваем элемент if ($(this).is(':animated')) { $(this).stop().animate({width: "78px"}, {duration: 400, easing:"easeInOutQuad"}) } else { // Сворачиваем элемент $(this).stop('animated:').animate({width: "78px"}, {duration: 450, easing:"easeInOutQuad"}); } }); }); </script>
Вариант два
Для второго варианта используем плагин jQuery Kwick, который добавляет функционала к нашему меню.
HTML
Разметка остается такой же, за исключением использования атрибута id вместо класса для пунктов меню:
<div class="jimgMenu_2"> <ul> <li id="landscapes"><a href="#nogo">Ландшафт</a></li> <li id="people"><a href="#nogo">Люди</a></li> <li id="nature"><a href="#nogo">Природа</a></li> <li id="abstract"><a href="#nogo">Абстракция</a></li> <li id="urban"><a href="#nogo">Город</a></li> </ul> </div>
CSS
Код CSS немного модифицирован для использования плагина Kwick.
.jimgMenu_2 { position:relative; margin: 0px 0px 0px 50px; padding: 0px; width:475px; height:200px; overflow: hidden; } .jimgMenu_2 ul { list-style: none; margin: 0px; padding: 0px; display: block; height: 200px; position: relative; } .jimgMenu_2 ul li { width: 95px; float: left; display: block; overflow: hidden; } .jimgMenu_2 ul li a { text-indent: -1000px; background:#fff repeat scroll 0%; border-right: 2px solid #fff; cursor:pointer; display:block; overflow: hidden; height: 200px; } .jimgMenu_2 ul li#landscapes a { background: url(images/landscapes.jpg) repeat scroll 0%; } .jimgMenu_2 ul li#people a { background: url(images/people.jpg) repeat scroll 0%; } .jimgMenu_2 ul li#nature a { background: url(images/nature.jpg) repeat scroll 0%; } .jimgMenu_2 ul li#abstract a { background: url(images/abstract.jpg) repeat scroll 0%; } .jimgMenu_2 ul li#urban a { background: url(images/urban.jpg) repeat scroll 0%; border-right-style: none; }
JavaScript
В раздел head страницы нужно вставить библиотеку jQuery и все плагины, которые используются для меню:
<link href="/css/jimgMenukwicks.css" rel="stylesheet" type="text/css" /> <script type="text/javascript" src="/js/jquery.js"></script> <script type="text/javascript" src="/js/jquery-easing-1.3.pack.js"></script> <script type="text/javascript" src="/js/jquery-easing-compatibility.1.2.pack.js"></script> <script type="text/javascript" src="/js/jquery.kwicks-1.5.1.pack.js"></script>
Остается только активировать плагин для работы нашего меню:
<script type="text/javascript"> $().ready(function() { $('.jimgMenu_2 ul').kwicks({max: 310, duration: 300, easing: 'easeOutQuad', complete: 'callback'}); }); </script>
Источник: http://feedproxy.google.com/~r/ruseller/CdHX/~3/qpFpFvc8Awc/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
«Web делает доступным все, для всех, везде и всегда. Если знания - это сила, то сила сейчас находится практически везде». К. Нордстрем, Й. Ридерстрале |
Мы создаем сайты, которые работают! Профессионально обслуживаем и продвигаем их , а также по всей России и ближнему зарубежью с 2006 года!
Как мы работаем
Заявка
Позвоните или оставьте заявку на сайте.
Консультация
Обсуждаем что именно Вам нужно и помогаем определить как это лучше сделать!
Договор
Заключаем договор на оказание услуг, в котором прописаны условия и обязанности обеих сторон.
Выполнение работ
Непосредственно оказание требующихся услуг и работ по вашему заданию.
Поддержка
Сдача выполненых работ, последующие корректировки и поддержка при необходимости.