Выскальзывающее название изображения
Эффект названий изображений, которые выскальзывают при наведении курсора мыши на картинку, можно создать с помощью набора взаимосвязанных элементов div. Но в данном уроке мы будем использовать структуру HTML5 для изображения с названием и CSS3 для задания стилей.
Зачем? Такое решение может помочь сохранить пространство в шаблоне. Сами по себе названия могут иметь отвлекающий от основной линии дизайн, поэтому их лучше выводить только тогда, когда они нужны. В любом случае, решение, предложенное в данном уроке, является простой демонстрацией возможностей. Будете ли вы его использовать, зависит от вас.
Структура HTML5
В ней нет ничего более, чем простая разметка для изображения с названием.
<figure> <img src="/yay.jpg" alt=""> <figcaption> yay!!! </figcaption> </figure>
Структура CSS
Элемент figure
содержит все остальное и является основным строительным блоком. Сущность нашей концепции начинает проявляться здесь. Элемент figure
нуждается в свойстве position: relative;
, что дает нам возможность абсолютно позиционировать название точно в том месте, где нам нужно. Также требуется свойство overflow: hidden;
, чтобы выскальзывающее название скрывалось при выходе за границы нашего элемента figure
.
figure { display: block; position: relative; overflow: hidden; } figcaption { position: absolute; background: rgba(0,0,0,0.75); color: white; padding: 10px 20px; }
Включаем выскальзывание
Нам нужно скрывать название, чтобы мы могли выводить его при наведении курсора мыши на изображение. Будем позиционировать название немного позади нижнего левого угла и скроем его с помощью установки прозрачности. Когда курсор мыши окажется над изображением, название будет выскальзывать на свое место и становиться видимым. Для выскальзывания будем использовать transition
.
figcaption { position: absolute; background: rgba(0,0,0,0.75); color: white; padding: 10px 20px; opacity: 0; bottom: 0; left: -30%; -webkit-transition: all 0.6s ease; -moz-transition: all 0.6s ease; -o-transition: all 0.6s ease; } figure:hover figcaption { opacity: 1; left: 0; }
Опции
На демонстрационной странице положение и направление выскальзывания названия различные для каждого изображения. Такое поведение реализовано с помощью добавления имени класса к изображению и позиционирования различными способами, в зависимости от класса.
.cap-left figcaption { bottom: 0; left: -30%; } .cap-left:hover figcaption { left: 0; } .cap-right figcaption { bottom: 0; right: -30%; } .cap-right:hover figcaption { right: 0; } .cap-top figcaption { left: 0; top: -30%; } .cap-top:hover figcaption { top: 0; } .cap-bot figcaption { left: 0; bottom: -30%;} .cap-bot:hover figcaption { bottom: 0; }
А как посетитель узнает, что там что-то есть?
Для того, чтобы посетитель мог иметь возможность видеть ваши великолепные и остроумные подписи под изображениями, надо поставить индикатор их присутствия. Мы будем использовать знак вопроса. Чтобы избежать избыточной разметки будем генерировать содержание в форме псевдо элемента для изображения.
figure:before { content: "?"; position: absolute; background: rgba(255,255,255,0.75); color: black; width: 24px; height: 24px; -webkit-border-radius: 12px; -moz-border-radius: 12px; border-radius: 12px; text-align: center; font-size: 14px; line-height: 24px; /* Только Fx 4 поддерживает трансформации для псевдо элементов... */ -webkit-transition: all 0.6s ease; -moz-transition: all 0.6s ease; -o-transition: all 0.6s ease; opacity: 0.75; } figure:hover:before { opacity: 0; }
Обратите внимание, что никаких свойств CSS позиционирования псевдо элемента, кроме position: absolute;
, нет. Позиционирование зависит от установленного класса опции. Возможно вы захотите размещать знак вопроса названии. Можно сделать так:
.cap-left:before { bottom: 10px; left: 10px; }
Готово!
Источник: http://feedproxy.google.com/~r/ruseller/CdHX/~3/IMgExjBf9-o/lessons.php
Дайджест новых статей по интернет-маркетингу на ваш email
Новые статьи и публикации
- 2024-04-22 » Комментирование кода и генерация документации в PHP
- 2024-04-22 » SEO в России и на Западе: в чем основные отличия
- 2024-04-22 » SEO для международного масштабирования
- 2024-04-22 » Как использовать XML-карты для продвижения сайта
- 2024-04-22 » Цифровой маркетинг: инструменты для продвижения и рекламы в 2024 году
- 2024-04-22 » Что такое CSS-модули и зачем они нам?
- 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 контейнере
"Тот, кто в совершенстве овладеет электронной почтой, будет миллионером в двадцать первом веке." |
Мы создаем сайты, которые работают! Профессионально обслуживаем и продвигаем их , а также по всей России и ближнему зарубежью с 2006 года!
Как мы работаем
Заявка
Позвоните или оставьте заявку на сайте.
Консультация
Обсуждаем что именно Вам нужно и помогаем определить как это лучше сделать!
Договор
Заключаем договор на оказание услуг, в котором прописаны условия и обязанности обеих сторон.
Выполнение работ
Непосредственно оказание требующихся услуг и работ по вашему заданию.
Поддержка
Сдача выполненых работ, последующие корректировки и поддержка при необходимости.