Используем псевдоселектор :target
Псевдоселектор :target
срабатывает, когда хэш URL адреса и идентификатор элемента совпадают.
<section id="voters"> Содержание </section>
:target { background: yellow; }
Пока адрес URL будет оставаться таким как на рисунке, описанный элемент section
будет иметь желтый фон, как указано в CSS.
Когда его использовать?
Одно из возможных применений - задание определенных стилей для различных "состояний". Когда страница имеет определенный хэш адреса URL, она находится в заданном состоянии. Это похоже на манипулирование классами. Все, что можно менять в классах, можно изменять и в :target
. Например: цвет, положение, скрывать и показывать элементы и многое другое.
В данном уроке мы коснемся кратких правил, помогающих определить, что ситуация пригодна для использования :target
:
- Когда необходимы "состояния"?
- Когда применять перескакивание вниз?
- Когда допустимо влиять на историю браузера?
Как получить нужный хэш в адресе URL?
Распространенная практика заключается в использовании ссылки, которая включает нужный хэш. Ссылка может быть внутренней (с той же страницы) или полноценным адресом URL, который заканчивается хэшем и значением. Например:
<a href="#voters">Переходим сюда</a> <a href="http://example.com/#specific-part">Переходим туда</a>
Поведение перескоков на странице
Вне зависимости от того, была ли ссылка с той же страницы или нет, браузер прокручивает страницу до тех пор, пока целевой элемент не окажется вверху экрана. Прокручивает до тех пор, пока возможно прокручивание. Данный факт очень важно осознавать, так как он ограничивает эксплуатацию "состояний".
Самое лучшее использование: выделение секций
Есть проблема: когда ссылка с хэшем отправляет вас в полет вниз по странице к соответствующей секции, браузер пытается установить ее точно вверх экрана. Но если не имеется достаточно пространства для прокручивания? Секция будет видна, но ее расположение окажется где-то посредине, что может ввести пользователя в заблуждение.
Представьте страницу с часто задаваемыми вопросами. Те пункты, что находятся внизу списка после перехода по ссылке придется искать на странице.
Однако для такой ситуации есть решение.
Можно выделять секции, на которые только что перешли по ссылке, с помощью затухающего маркера.
Представим структуру страницы с навигацией:
<nav> <a href="#one">1</a> <a href="#two">2</a> <a href="#three">3</a> </nav> <section> <div id="one"><h2>Один</h2>Pellentesque habitant morbi tristique senectus et netus et malesuada fames ac turpis egestas. Vestibulum tortor quam, feugiat vitae, ultricies eget, tempor sit amet, ante. Donec eu libero sit amet quam egestas semper. Aenean ultricies mi vitae est. Mauris placerat eleifend leo. Quisque sit amet est et sapien ullamcorper pharetra. Vestibulum erat wisi, condimentum sed, commodo vitae, ornare sit amet, wisi. Aenean fermentum, elit eget tincidunt condimentum, eros ipsum rutrum orci, sagittis tempus lacus enim ac dui. Donec non enim in turpis pulvinar facilisis. Ut felis. Praesent dapibus, neque id cursus faucibus, tortor neque egestas augue, eu vulputate magna eros eu erat. Aliquam erat volutpat. Nam dui mi, tincidunt quis, accumsan porttitor, facilisis luctus, metus</div> <div id="two"><h2>Два</h2>Pellentesque habitant morbi tristique senectus et netus et malesuada fames ac turpis egestas. Vestibulum tortor quam, feugiat vitae, ultricies eget, tempor sit amet, ante. Donec eu libero sit amet quam egestas semper. Aenean ultricies mi vitae est. Mauris placerat eleifend leo. Quisque sit amet est et sapien ullamcorper pharetra. Vestibulum erat wisi, condimentum sed, commodo vitae, ornare sit amet, wisi. Aenean fermentum, elit eget tincidunt condimentum, eros ipsum rutrum orci, sagittis tempus lacus enim ac dui. Donec non enim in turpis pulvinar facilisis. Ut felis. Praesent dapibus, neque id cursus faucibus, tortor neque egestas augue, eu vulputate magna eros eu erat. Aliquam erat volutpat. Nam dui mi, tincidunt quis, accumsan porttitor, facilisis luctus, metus</div> <div id="three"><h2>Три</h2>Pellentesque habitant morbi tristique senectus et netus et malesuada fames ac turpis egestas. Vestibulum tortor quam, feugiat vitae, ultricies eget, tempor sit amet, ante. Donec eu libero sit amet quam egestas semper. Aenean ultricies mi vitae est. Mauris placerat eleifend leo. Quisque sit amet est et sapien ullamcorper pharetra. Vestibulum erat wisi, condimentum sed, commodo vitae, ornare sit amet, wisi. Aenean fermentum, elit eget tincidunt condimentum, eros ipsum rutrum orci, sagittis tempus lacus enim ac dui. Donec non enim in turpis pulvinar facilisis. Ut felis. Praesent dapibus, neque id cursus faucibus, tortor neque egestas augue, eu vulputate magna eros eu erat. Aliquam erat volutpat. Nam dui mi, tincidunt quis, accumsan porttitor, facilisis luctus, metus</div> </section>?
Когда секция выделяется селектором :target,
она будет немного отодвигаться вправо с помощью трансформации translateX
(чтобы предотвратить ломку текста или другие нежелательные эффекты можно использовать отступ) и левая граница будет моргать красным с помощью анимации.
:target { -webkit-animation: highlight 1s ease; -moz-animation: highlight 1s ease; -webkit-transform: translateX(20px); -moz-transform: translateX(20px); -ms-transform: translateX(20px); -o-transform: translateX(20px); } @-webkit-keyframes highlight { 0% { border-left-color: red; } 100% { border-left-color: white; } } @-moz-keyframes highlight { 0% { border-left-color: red; } 100% { border-left-color: white; } } section > div { border-left: 40px solid white; padding: 10px; -webkit-transition: all 0.5s ease; -moz-transition: all 0.5s ease; -ms-transition: all 0.5s ease; -o-transition: all 0.5s ease; padding-right: 50px; margin-left: -20px; }
Вот такое получается интересное применение псевдоселектора.
Предотвращаем перескок
Допустим\. вам нравится идея использовать :target
для определения состояний страницы, но поведение перескока мешает. Можно изменять хэш в адресе URL без перескока.
Используя jQuery вы можете перехватывать все ссылки с хэшем предотвращая поведение по умолчанию, а с помощью функций pushState
или replaceState
- изменять URL без перемещений по странице.
$("a[href^=#]").on("click", function(e) { e.preventDefault(); history.pushState({}, "", this.href); });
Использование replaceState
изменяет URL без добавления в историю браузера. Иногда такое действие требуется. Теперь у вас есть альтернатива стандартному поведению нажатия на ссылку, которое всегда добавляется в журнал браузера.
Плохие новости
Когда URL изменяет хеш с помощью функций можно подумать, что текущая цель изменилась и будут использоваться новые правила CSS. Но нет (проверялось в WebKit и Firefox на момент написания статьи). Такая ошибка.
Теоретически можно вычислять и сохранять текущую позицию страницы, давать ссылке изменить ее, и затем возвращать обратно. Но выглядеть сей процесс будет ужасно.
Источник: http://feedproxy.google.com/~r/ruseller/CdHX/~3/f9lPotH9lVo/lessons.php


Дайджест новых статей по интернет-маркетингу на ваш email
Новые статьи и публикации
- 2025-03-14 » SPF-запись
- 2025-03-07 » SEO на маркетплейсах: как оптимизировать карточку товара для поисковой выдачи
- 2025-02-18 » Топ-10 бесплатных нейросетей для генерации изображений: лучшие ии генераторы 2024 года
- 2025-02-11 » Критическая уязвимость в 1С-Битрикс
- 2025-02-11 » Google Search Console: руководство для начинающих вебмастеров
- 2025-02-11 » Методы измерения результативности рекламных кампаний: плюсы и минусы
- 2025-02-11 » Тренды SEO в 2025 году
- 2025-02-10 » Свой Google в локалке. Ищем иголку в стоге сена
- 2025-01-29 » SEO — это комплексная работа. Шесть главных факторов ранжирования сайтов
- 2025-01-29 » Гайд для главной страницы e-commerce сайта: как оформить, чтобы повысить конверсию
- 2025-01-20 » Krea AI выпустила бесплатную функцию преобразования изображений в 3D-объекты — их можно вращать и вписывать в фотографии
- 2025-01-19 » Отзывы на Яндекс Картах: как пройти модерацию
- 2025-01-15 » Топ-6 лучших российских нейросетей, в которых можно генерировать тексты и изображения бесплатно и без VPN
- 2025-01-14 » 15 бесплатных способов узнать, чем интересуется ваша аудитория
- 2025-01-11 » Бездепозитные бонусы в казино за регистрацию с выводом: особенности и возможности получения
- 2025-01-09 » Новая модель LAM способна выполнять задачи в Word
- 2024-12-26 » Универсальный промпт для нейросети: как выжать максимум из ChatGPT, YandexGPT, Gemini, Claude в 2025
- 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 » Интеграция с Яндекс Еда
Большинство людей, стремящихся к цели, способны скорее сделать одно большое усилие, чем упорно идти избранной дорогой; из-за лени и непостоянства они часто утрачивают плоды лучших своих начинаний и дают обогнать себя тем, кто отправился в путь позднее, чем они, и шел медленней, но зато безостановочно Лабрюйер Жан де (1645-1696) - французский писатель, мастер афористической публицистики |
Мы создаем сайты, которые работают! Профессионально обслуживаем и продвигаем их , а также по всей России и ближнему зарубежью с 2006 года!
Как мы работаем
Заявка
Позвоните или оставьте заявку на сайте.
Консультация
Обсуждаем что именно Вам нужно и помогаем определить как это лучше сделать!
Договор
Заключаем договор на оказание услуг, в котором прописаны условия и обязанности обеих сторон.
Выполнение работ
Непосредственно оказание требующихся услуг и работ по вашему заданию.
Поддержка
Сдача выполненых работ, последующие корректировки и поддержка при необходимости.
Или напишите нам в WhatsApp
Или напишите нам в WhatsApp