Как сделать HTML-текст невыбираемым [дублировать]
-
22-09-2019 - |
Вопрос
На этот вопрос уже есть ответ здесь:
- Как отключить выделение текста 41 ответ
Я хотел бы добавить текст на свою веб-страницу в качестве метки и сделать его недоступным для выбора.
Другими словами, когда курсор мыши находится над текстом, я бы хотел, чтобы он вообще не превращался в курсор для выбора текста.
Хорошим примером того, чего я пытаюсь достичь, являются кнопки на этом веб-сайте (Вопросы, теги, пользователи, ...)
Решение
Вы не можете сделать это с помощью обычного ванильного HTML, поэтому JSF здесь тоже мало что может для вас сделать.
Если вы нацелены приличные браузеры только, тогда просто используйте CSS3:
.unselectable {
-webkit-touch-callout: none;
-webkit-user-select: none;
-khtml-user-select: none;
-moz-user-select: none;
-ms-user-select: none;
user-select: none;
}
<label class="unselectable">Unselectable label</label>
Если вы хотите охватить и старые браузеры, то рассмотрите этот запасной вариант JavaScript:
<!doctype html>
<html lang="en">
<head>
<title>SO question 2310734</title>
<script>
window.onload = function() {
var labels = document.getElementsByTagName('label');
for (var i = 0; i < labels.length; i++) {
disableSelection(labels[i]);
}
};
function disableSelection(element) {
if (typeof element.onselectstart != 'undefined') {
element.onselectstart = function() { return false; };
} else if (typeof element.style.MozUserSelect != 'undefined') {
element.style.MozUserSelect = 'none';
} else {
element.onmousedown = function() { return false; };
}
}
</script>
</head>
<body>
<label>Try to select this</label>
</body>
</html>
Если вы уже используете jQuery - jQuery - запрос, тогда вот еще один пример , который добавляет новую функцию disableSelection()
в jQuery, чтобы вы могли использовать его в любом месте вашего кода jQuery:
<!doctype html>
<html lang="en">
<head>
<title>SO question 2310734 with jQuery</title>
<script src="http://code.jquery.com/jquery-latest.min.js"></script>
<script>
$.fn.extend({
disableSelection: function() {
this.each(function() {
if (typeof this.onselectstart != 'undefined') {
this.onselectstart = function() { return false; };
} else if (typeof this.style.MozUserSelect != 'undefined') {
this.style.MozUserSelect = 'none';
} else {
this.onmousedown = function() { return false; };
}
});
}
});
$(document).ready(function() {
$('label').disableSelection();
});
</script>
</head>
<body>
<label>Try to select this</label>
</body>
</html>
Другие советы
Никто здесь не опубликовал ответ со всеми правильными вариантами CSS, так что вот он:
-webkit-touch-callout: none;
-webkit-user-select: none;
-khtml-user-select: none;
-moz-user-select: none;
-ms-user-select: none;
user-select: none;
Полное современное решение вашей проблемы основано исключительно на CSS, но обратите внимание, что старые браузеры не будут его поддерживать, и в этих случаях вам нужно будет прибегнуть к решениям, подобным тем, которые предоставили другие.
Итак, в чистом CSS:
-webkit-user-select: none;
-khtml-user-select: none;
-moz-user-select: none;
-ms-user-select: none;
-o-user-select: none;
user-select: none;
Однако курсор мыши по-прежнему будет перемещаться на каретку при наведении на текст элемента, поэтому вы добавляете к этому:
cursor: default;
Современный CSS довольно элегантен.
Я изменил плагин jQuery, опубликованный выше, чтобы он работал с живыми элементами.
(function ($) {
$.fn.disableSelection = function () {
return this.each(function () {
if (typeof this.onselectstart != 'undefined') {
this.onselectstart = function() { return false; };
} else if (typeof this.style.MozUserSelect != 'undefined') {
this.style.MozUserSelect = 'none';
} else {
this.onmousedown = function() { return false; };
}
});
};
})(jQuery);
Тогда вы могли бы сделать что-то вроде:
$(document).ready(function() {
$('label').disableSelection();
// Or to make everything unselectable
$('*').disableSelection();
});