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