Используем псевдоселектор :target


Псевдоселектор :target срабатывает, когда хэш URL адреса и идентификатор элемента совпадают. Хэш URL адреса 1 <section id="voters"> 2 Содержание 3 </section> 1 :target { 2 background: yellow; 3 } Пока адрес URL будет оставаться таким как на рисунке, описанный элемент section будет иметь желтый фон, как указано в CSS. Когда его использовать? Одно из возможных применений - задание определенных стилей для различных "состояний". Когда страница имеет определенный хэш адреса URL, она находится в заданном состоянии. Это похоже на манипулирование классами. Все, что можно менять в классах, можно изменять и в :target. Например: цвет, положение, скрывать и показывать элементы и многое другое. В данном уроке мы коснемся кратких правил, помогающих определить, что ситуация пригодна для использования :target: Когда необходимы "состояния"? Когда применять перескакивание вниз? Когда допустимо влиять на историю браузера? Как получить нужный хэш в адресе URL? Распространенная практика заключается в использовании ссылки, которая включает нужный хэш. Ссылка может быть внутренней (с той же страницы) или полноценным адресом URL, который заканчивается хэшем и значением. Например: 1 <a href="#voters">Переходим сюда</a> 2 3 <a href="http://example.com/#specific-part">Переходим туда</a> Поведение перескоков на странице Вне зависимости от того, была ли ссылка с той же страницы или нет, браузер прокручивает страницу до тех пор, пока целевой элемент не окажется вверху экрана. Прокручивает до тех пор, пока возможно прокручивание. Данный факт очень важно осознавать, так как он ограничивает эксплуатацию "состояний". Самое лучшее использование: выделение секций Есть проблема: когда ссылка с хэшем отправляет вас в полет вниз по странице к соответствующей секции, браузер пытается установить ее точно вверх экрана. Но если не имеется достаточно пространства для прокручивания? Секция будет видна, но ее расположение окажется где-то посредине, что может ввести пользователя в заблуждение. Проблема с прокруткой Представьте страницу с часто задаваемыми вопросами. Те пункты, что находятся внизу списка после перехода по ссылке придется искать на странице. Однако для такой ситуации есть решение. Можно выделять секции, на которые только что перешли по ссылке, с помощью затухающего маркера. Представим структуру страницы с навигацией: 01 <nav> 02 <a href="#one">1</a> 03 <a href="#two">2</a> 04 <a href="#three">3</a> 05 </nav> 06 07 <section> 08 <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> 09 <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> 10 <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> 11 </section>? Когда секция выделяется селектором :target, она будет немного отодвигаться вправо с помощью трансформации translateX (чтобы предотвратить ломку текста или другие нежелательные эффекты можно использовать отступ) и левая граница будет моргать красным с помощью анимации. 01 :target { 02 -webkit-animation: highlight 1s ease; 03 -moz-animation: highlight 1s ease; 04 -webkit-transform: translateX(20px); 05 -moz-transform: translateX(20px); 06 -ms-transform: translateX(20px); 07 -o-transform: translateX(20px); 08 } 09 @-webkit-keyframes highlight { 10 0% { border-left-color: red; } 11 100% { border-left-color: white; } 12 } 13 @-moz-keyframes highlight { 14 0% { border-left-color: red; } 15 100% { border-left-color: white; } 16 } 17 section > div { 18 border-left: 40px solid white; 19 padding: 10px; 20 -webkit-transition: all 0.5s ease; 21 -moz-transition: all 0.5s ease; 22 -ms-transition: all 0.5s ease; 23 -o-transition: all 0.5s ease; 24 padding-right: 50px; 25 margin-left: -20px; 26 } Вот такое получается интересное применение псевдоселектора. Предотвращаем перескок Допустим\. вам нравится идея использовать :target для определения состояний страницы, но поведение перескока мешает. Можно изменять хэш в адресе URL без перескока. Используя jQuery вы можете перехватывать все ссылки с хэшем предотвращая поведение по умолчанию, а с помощью функций pushState или replaceState - изменять URL без перемещений по странице. 1 $("a[href^=#]").on("click", function(e) { 2 e.preventDefault(); 3 history.pushState({}, "", this.href); 4 }); Использование replaceState изменяет URL без добавления в историю браузера. Иногда такое действие требуется. Теперь у вас есть альтернатива стандартному поведению нажатия на ссылку, которое всегда добавляется в журнал браузера. Плохие новости Когда URL изменяет хеш с помощью функций можно подумать, что текущая цель изменилась и будут использоваться новые правила CSS. Но нет (проверялось в WebKit и Firefox на момент написания статьи). Такая ошибка. Теоретически можно вычислять и сохранять текущую позицию страницы, давать ссылке изменить ее, и затем возвращать обратно. Но выглядеть сей процесс будет ужасно.