Отключение выделения текста в HTML: CSS и JavaScript решение

Пройдите тест, узнайте какой профессии подходите

Я предпочитаю
0%
Работать самостоятельно и не зависеть от других
Работать в команде и рассчитывать на помощь коллег
Организовывать и контролировать процесс работы

Быстрый ответ

В CSS существует элегантное решение для отключения функции выделения текста. Вам нужно будет применить свойство user-select: none, обеспечивая тем самым защиту от выделения текста во всех основных браузерах.

Вот пример кода:

CSS
Скопировать код
.no-select {
  -webkit-user-select: none; /* Chrome/Safari */
  -moz-user-select: none; /* Firefox */
  -ms-user-select: none; /* IE/Edge */
  user-select: none; /* Стандартный синтаксис */
}

Чтобы применить этот класс, добавьте class="no-select" к HTML-элементу, который вас интересует:

HTML
Скопировать код
<div class="no-select">Вы не можете выделить этот текст. Придется поверить на слово!</div>

Для улучшения надёжности стоит дополнить CSS-решение использованием JavaScript, создав дополнительный слой защиты от выделения во время пользовательских взаимодействий.

Кинга Идем в IT: пошаговый план для смены профессии

Погружение: методы и рассмотрения

За рамками CSS: Атрибуты HTML и события JavaScript

Расширьте арсенал инструментов для предотвращения выделения текста, используя HTML-атрибуты и события JavaScript. Применяйте атрибут unselectable="on" для поддержки старых браузеров, а также атрибуты onselectstart и onmousedown, чтобы блокировать выделение текста при помощи мыши.

Подробнее об этом расскажет наш спикер на видео
skypro youtube speaker

Учитывайте опыт пользователя: UX и доступность

Функция отключения выделения текста может отрицательно отразиться на пользовательском опыте и доступности сайта. Пользователи могут захотеть скопировать текст по разным причинам — например, для того чтобы процитировать вашу статью или распространить информацию. Следовательно, отключайте выделение текста только там, где это действительно нужно для сохранения удобства интерфейса.

Кросс-браузерная совместимость

Проверьте работоспособность вашего решения в различных браузерах. Свойство user-select, хоть и весьма удобно, не может гордиться идеальной поддержкой. Именно поэтому тщательная проверка на совместимость имеет критическое значение.

Псевдоэлементы к вашим услугам

Если визуальное выделение не ставит вас в тупик, но копирование контента — да, тогда псевдоэлемент ::selection будет весьма полезен. Он позволяет стилизовать выделенный текст без нарушения политики "читать можно, но копировать — нет".

JavaScript в действии: Обработчики событий

Если вам требуется большая гибкость, то стоит обратиться к возможностям JavaScript и его обработчиков событий. Они помогут вам предотвратить попытки выделения текста, которые используются в определённых браузерах.

Пример кода:

JS
Скопировать код
// Добавить обработчик событий для блокировки выделения текста легко, как гулять по парку в хорошую погоду.
document.addEventListener('mousedown', function(event){
  if (event.target.className.includes('no-select')) {
    event.preventDefault();
  }
}, false);

Придаем жизнь взаимодействиям

Стилизация выделений

Используйте псевдоэлемент ::selection, чтобы настроить внешний вид выделения текста. Сочетание этого элемента с user-select: none обеспечит защиту от нежелательного копирования содержимого и в то же время улучшит визуальное восприятие.

CSS
Скопировать код
.no-select::selection {
  background: transparent; /* Какое выделение? Не вижу! */
  color: inherit; /* Цвет текста сохраняется, даже если кто-то пытается его выделить */
}

.no-select::-moz-selection {
  background: transparent; /* Не забыли и про Firefox */
  color: inherit;
}

.no-select::-webkit-selection {
  background: transparent; /* Также учтено для Chrome/Safari */
  color: inherit;
}

Разработка интерфейса: Удобство использования

Тщательно продумайте, как запрет на выделение текста влияет на путь пользователя сквозь ваш интерфейс и на удобство его использования. Ваша цель — предоставить им максимально комфортное взаимодействие, создавая путь ровный и без препятствий.

Учет особенностей браузеров

Каждый браузер уникален и имеет свой набор специфических функций. Не забывайте об этом при применении запрета на выделение текста. Адаптируйте ваше решение при помощи JavaScript, словно шьете одежду по личному заказу.

Стандарты CSS свойств: Мифы or Reality?

Следите за актуальными данными о CSS свойствах, таких как user-select, поскольку спецификации могут изменяться так же быстро, как и направление ветра. Постоянно обновляйте свои знания и не прекращайте самообучение.

Визуализация

Отключение выделения текста делает ваш контент подобным недосягаемому экспонату музея, к которому можно только приглядываться, но не трогать.

CSS
Скопировать код
/* CSS: Текст теперь недоступен, словно экспонат в музее */
.no-select {
  user-select: none; /* Стандартный синтаксис */
  -webkit-user-select: none; /* Chrome/Safari */
  -moz-user-select: none; /* Firefox */
  -ms-user-select: none; /* IE/Edge */
}

Использование JavaScript добавит вашему контенту дополнительную защиту, создаст новый уровень охраны, оберегающий ваши ценности от несанкционированных касаний посетителей 🏛️.

Полезные материалы

  1. user-select | CSS-Tricks — всестороннее руководство по использованию свойства CSS user-select 💅.
  2. user-select – CSS | MDN — подробное описание свойства user-select на портале MDN 📚.
  3. css – How to disable text selection highlighting – Stack Overflow — полезные советы от сообщества разработчиков 🧑‍🤝‍🧑.
  4. CSS user-select property — подробное руководство по свойству user-select от W3Schools 🎓.
  5. Browser default actions — обзор методов предотвращения стандартных действий браузера с помощью JavaScript 🕵️.
  6. "user-select" | Can I use... Support tables for HTML5, CSS3, etc — проверка совместимости свойства user-select между браузерами 🌐.
  7. Запрет выделения текста | CodePen — наблюдайте за работой user-select в реальном времени на CodePen. Обратите внимание на точность исходных данных!
Проверь как ты усвоил материалы статьи
Пройди тест и узнай насколько ты лучше других читателей
Какое CSS-свойство используется для отключения выделения текста?
1 / 5