Используем псевдоселектор :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
Новые статьи и публикации
- 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 года!
Как мы работаем
Заявка
Позвоните или оставьте заявку на сайте.
Консультация
Обсуждаем что именно Вам нужно и помогаем определить как это лучше сделать!
Договор
Заключаем договор на оказание услуг, в котором прописаны условия и обязанности обеих сторон.
Выполнение работ
Непосредственно оказание требующихся услуг и работ по вашему заданию.
Поддержка
Сдача выполненых работ, последующие корректировки и поддержка при необходимости.