Как скрыть элемент с помощью css : 4 простых способа.
Привет, дорогие читатели, на связи Шевченко Вячеслав и сегодня очередная статья из серии css о том как скрыть элемент на странице. На днях я публиковал статью о переменных в css, рекомендую к прочтению.
Существует несколько способов скрыть блок в CSS. Можно указать opacity: 0
, visability: hidden
, display: none
или установить крайние значения для абсолютного позиционирования.
Вы можете спросить зачем так много способов, ведь они делат одно и тоже? Если разобраться лучше то, на самом деле, они отличаются друг от друга. И эта разница диктует, какой из них должен использоваться в конкретной ситуации. Дальше вы узнаете незначительные различия, которые вы должны принимать во внимание, когда скрываете элемент.
Opacity
Свойство opacity
устанавливает прозрачность элемента. Это означает, что opacity: 0
скрывает div только визуально. Он как и раньше занимает свою позицию, влияет на макет веб-страницы и будет доступен для взаимодействия.
Если вы собираетесь использовать свойство непрозрачности, чтобы скрыть элемент от пользователя, то, к сожалению, это не лучший вариант. Элемент и его содержание доступно, так же как и все другие элементы на веб-странице. Другими словами, элемент ведет себя так, словно он непрозрачный.
Свойство непрозрачности можно анимировать и использовать для создания эффектов. Любой элемент с непрозрачностью меньше 1 также создаст новый контекст наложения.
При наведении на второй блок, элемент плавно переходит от состояния полной прозрачности до opacity: 1
. Блок также имеет cursor: pointer
, чтобы показать, что с ним можно взаимодействовать.
Visibility
Следующий способ скрыть блок или текст свойство — visibility
. Значение hidden
будет скрывать элемент. Так же, как и свойство opacity
, скрытый элемент будет влиять на макет нашей веб-страницы. Единственное отличие заключается в том, что на этот раз он не будет доступен для взаимодействия. Кроме того, он будет скрыт от чтения с экрана.
Это свойство можно анимировать до тех пор, пока начальные и конечные состояния имеют различные значения. Это гарантирует плавный переход между состояниями видимости.
.hide { visibility: hidden; }
.hide { visibility: hidden; } |
Ниже пример, можете посмотреть разницу.
Обратите внимание на то, что потомки элемента с visibility: hidden
могут быть видимыми, если их свойство visibility: visible
. Попробуйте навести курсор только на скрытый элемент, а не на пункт внутри. Вы увидите, что тип курсора не изменится. Кроме того, если вы попытаетесь щелкнуть на элемент, ваши клики не будут учтены.
Тег внутри будет как и раньше захватывать все события мыши. Как только вы наведете курсор мыши на текст он станет видимым и начнет регистрировать события.
Display
Свойство display
скрывает элемент со страницы целиком. При display: none
элемент вырывается из потока и соседние элементы в DOM перестают на него реагировать.
Все дочерние элементы также будут скрыты. К этому свойству не применяют анимацию, так как переход между различными состояниями всегда будет резким.
Обратите внимание, что элемент по-прежнему доступен через DOM. Вы можете работать с ним так же, как с любым другим элементом.
.hide { display: none; }
.hide { display: none; } |
Второй блок имеет элемент с display: block
, но этот пункт остается невидимым. Это еще одна разница между visibility: hidden
display:none
. В первом случае, любой потомок, который явно задает visibility: visible
станет видимым, тогда как с display
все иначе — все потомки остаются скрытыми независимо от значения свойства.Теперь, наведите курсор мыши на первый блок несколько раз. Есть? Нажмите на первый блок. Это должно сделать второй блок видимым. Значение внутри должно стать больше 0. Это происходит потому, что элемент, несмотря на то, что он скрыт от пользователей, все еще доступен с помощью JavaScript.
Position
Допустим, у вас есть элемент, с которым вы хотели бы взаимодействовать, но вы не хотите, чтобы он влиял на верстку страницы. Никакое свойство до этого не может справиться с этой задачей должным образом. Одна вещь, которую вы можете сделать в этой ситуации — переместить элемент в окне. Таким образом, это не повлияет на макет. Вот CSS, чтобы сделать это:
.hide { position: absolute; top: -9999px; left: -9999px; }
.hide { position: absolute; top: -9999px; left: -9999px; } |
Ниже пример который продемонстирует, как абсолютное позиционирование скрывает элементы:
Основная идея здесь — установить негативные top
и left
значение так, чтобы элемент больше не было видно на экране.
В этой статье мы рассмотрели как скрыть элемент с помощью CSS, надеюсь вы теперь с легкостью сможете подобрать для себя подходящий способ.
Если эта статья оказалась полезной для вас, поделитесь ей с социальных сетях. Этим вы поддержите ресурс.
Так же подписывайтесь в наши группы facebook и vkontakte. До встречи в новых статьях!
comments powered by HyperCommentsКак скрыть элементы со страницы, при помощи CSS
Иногда появляется необходимость скрыть некоторые элементы с сайта (блоки, картинки, div и так далее), либо просто скрыть текст при помощи CSS. Для этого существует несколько различных способов, которые отличаются по эффекту. Далее вы можете узнать о них.
При помощи свойства display
Это наверное самый универсальный и удобный способ. У свойства display может в качестве значения принимать none, именно это значение и скрывает блок со страницы. В том числе так можно скрыть картинки, текст, таблицы и другие.
CSS код для div, который мы хотим полностью убрать со страницы:
div {display:none;} /* говорит браузеру, что этот элемент не нужно отображать на странице */
Какой эффект он производит? Полностью скрывает элемент со страницы, его не чувствуют другие элемент, как будто его попросту не было.
Когда стоит использовать? Когда вам нужно на некоторое время убрать элемент, чтобы посмотреть, как выглядит страница без него.
При помощи свойств position и left/right/top/bottom
Суть состоит в том, что свойству position задается absolute, т.е. абсолютное позиционирование, которое позволяет убрать эффект присутствия элемента на странице — другие элементы его игнорируют. А потом при помощи left/right/top/bottom убрать его за пределы страницы.
CSS код для div, который мы хотим полностью убрать со страницы:
div { position:absolute; /* позиционируем блок абсолютно на странице */ top:-9999px; /* при помощи отрицательного значения убираем блок высоко вверх */ }
Какой эффект он производит? Полностью скрывает элемент со страницы, его не чувствуют другие элемент, как будто его попросту не было.
Когда стоит использовать? Дело в том, что физически элемент остается на странице, просто пользователи его не видят, а вот различные поисковики, анализаторы страниц видят и можно использовать его для них.
При помощи свойства opacity
Свойство opacity задает прозрачность блока, задав в качестве значения 0, получится, что элемент скроется со страницы, но его физическое местоположение останется. Добавив position: absolute; полностью уберет и физическое положение элемента на странице.
CSS код для div, который мы хотим полностью убрать со страницы:
div { opacity:0; /* делает элемент полностью прозрачным */ }
Какой эффект он производит? Скрывает блоки, текст со страницы для глаз пользователей, но для других элементов блок и текст на месте.
Когда стоит использовать? Если вы хотите, чтобы текст (или элементы) появлялись при наведении на них.
Показать / скрыть div при клике с помощью CSS
Немного взлома, но это работает. Обратите внимание, что label
тег можно разместить в любом месте. Ключевые части:
- CSS
input:checked+div
выбирает div непосредственно рядом с / после ввода - На ярлыке
for
написано «флажок» (или просто уберите ярлык и просто установите флажок) display:none
прячет вещи
Код:
<head> <style> #sidebar {height:100%; background:blue; width:200px; clear:none; float:left;} #content {height:100%; background:green; width:400px; clear:none; float:left;} label {background:yellow;float:left;} input{display:none;} input:checked+#sidebar{display:none;} </style> </head> <body> <div> <label for="hider">Hide</label> <input type="checkbox"> <div>foo</div> <div>hello</div> </div> </body>
РЕДАКТИРОВАТЬ: Извините, возможно, прочитал вопрос лучше.
Можно также использовать элементы css3 для создания эффекта слайда / затухания. Я не достаточно знаком с ними, чтобы сильно помочь с этим аспектом, но они существуют. Хотя поддержка браузера ненадежна.
Вы могли бы объединить вышеупомянутый эффект с javascript, чтобы использовать причудливые переходы и все еще иметь отступление. В jquery есть css
метод, позволяющий переопределить вышеприведенное slide
и fade
для переходов.
- Тильда (~) означает, что какой-то брат после; не следующий брат, как плюс (+).
[key="value"]
является селектором атрибута- Радиокнопки должны иметь одинаковое имя
Чтобы объединить вкладки вместе можно использовать:
<html>
<head>
<style>
input[value="1"]:checked ~ div[id="1"]{
display:none;
}
input[value="2"]:checked ~ div[id="2"]{
display:none;
}
</style>
</head>
<body>
<input type="radio" name="hider" value="1">
<input type="radio" name="hider" value="2">
<div>div 1</div>
<div>div 2</div>
</body>
</html>
Автор: Aaron Schif
Размещён: 12.06.2013 09:57Порой при разработке веб-страниц иногда требуется «спрятать» конкретные элементы. Вы, конечно, можете просто удалить эти элементы из HTML-разметки. Но это не выход из положения. Чтобы сохранить элемент, но скрыть его, необходимо использовать CSS или HTML hidden.
Два самых распространенных способа скрыть элемент — это свойства CSS «display» и «visibility». На первый взгляд, кажется, что оба свойства делают одно и то же. Но каждое из них имеет свои отличительные особенности, о которых следует знать.
Visibility
При использовании visibility: hidden элемент не отображается в браузере. Но скрытый элемент все еще занимает место в дизайне страницы. Это выглядит так, будто вы сделали элемент невидимым, но он все еще остается на своем месте и занимает пространство.
Если вы размещаете на веб-странице тег DIV и используете CSS, чтобы придать ему размер 100 на 100 пикселей, свойство visibility: hidden делает блок невидимым на экране. Но текст, следующий за ним, будет размещаться таким образом, словно этот блок все еще присутствует на странице.
Я бы использовал hidden HTML input, чтобы сначала спрятать этот элемент, а затем вернуть его обратно при наведении курсора. Это один из примеров использования этого свойства.
Display
В отличие от свойства visibility, при использовании которого элемент остается в потоке документа, display: none полностью убирает элемент из документа. Он больше не занимает места даже несмотря на то, что он еще находится в исходном коде. Элемент действительно удаляется из потока документа. Но если вы неправильно используете это свойство, оно может полностью разрушить страницу!
Я часто использую display: none, когда тестирую веб-страницу. Когда мне нужно ненадолго скрыть какую-либо область страницы, чтобы я смог протестировать другую. Но необходимо помнить, что скрытый элемент нужно вернуть обратно на веб-страницу до того, как она будет добавлена на сайт. Сделать это нужно потому, что элемент, удаленный из потока документа данным методом не виден поисковикам. В прошлом этот способ использовался хакерами, чтобы влиять на рейтинг в поисковых системах. Поэтому элементы hide HTML, которые не отображаются, могут восприниматься Google как негативный сигнал.
Свойство display:none полезно при создании адаптивного сайта, в котором присутствуют элементы, доступные только для одного размера экрана, но не для других.
Также можно использовать display: none, чтобы скрыть элемент, а затем вернуть его обратно при помощи медиа-запросов. Это корректное использование свойства display: none, поскольку вы не пытаетесь скрыть что-либо с целью совершения нарушений.
CSS: Как скрыть элемент HTML
CSS свойства display
и visibility
позволяют скрывать элементы (делать их невидимыми) и полностью убирать элементы из HTML разметки (в этом случае браузер игнорирует элемент, при построении разметки страницы).
Блочные и строчные элементы
Большинство элементов в CSS классифицируются как блочные (block
) или строчные (inline
), и это влияет на то, как эти элементы будут отображаться по умолчанию на веб-странице.
Важно знать к какому типу относится элемент, так как не все CSS свойства работают с обоими типами элементов. Некоторые CSS свойства работают только с блочными элементами, другие только со строчными.
CSS свойство display позволяет переопределить тип элемента, заданный по умолчанию. Что в свою очередь, позволят по необходимости изменять тип элемента со строчного на блочный или с блочного на строчный.
Строчные элементы
Элемент определённый как строчный, будет занимать только необходимое количество места на веб-странице (занимаемое место зависит от содержимого строчного элемента), кроме этого такие элементы:
- игнорируют верхний и нижний внешний отступ, если он применен
- игнорируют свойства height и width
- могут быть выровнены с помощью свойства vertical-align
Строчный элемент можно сделать блочным если установить для свойства display
значение block
или если сделать элемент плавающим. Плавающие элементы автоматически становятся блочными, то есть появляется возможность регулировать размер элемента и задавать внешние отступы.
Блочные элементы
Блочные элементы всегда начинаются с новой строки и занимают всю доступную ширину, если ширина для элемента не была установлена. Кроме этого блочные элементы:
- могут иметь внешние и внутренние отступы
- растягиваются по высоте под свое содержимое
- не выравниваются свойством vertical-align
Строчно-блочные элементы
Строчно-блочное отображение элемента задается значением inline-block
. В основном это способ сделать элемент строчным, но сохранить его «блочные» возможности: изменение высоты и ширины элемента, регулирование размеров внешних и внутренних отступов.
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title>Название документа</title> <style> p { display: inline; } span { display: block; } li { display: inline-block; } </style> </head> <body> <p>Абзац 1.</p><p>абзац 2.</p> <span>Практическое применение свойства display мы рассмотрим</span> <span>в главе "CSS меню"</span> <ul> <li>Пункт 1</li> <li>Пункт 2</li> <li>Пункт 3</li> </ul> </body> </html>Попробовать »
Примечание: значение inline-block
не поддерживается в IE7 и более ранних версиях.
Скрытие элементов
В CSS есть возможность временного или постоянного скрытия некоторых элементов веб-страницы. Стоит обратить внимание на то, что скрытые элементы не будут отображаться только на веб-странице, но их можно будет посмотреть в исходном коде HTML-документа. Для скрытия элементов используется или свойство display
со значением none
или свойство visibility со значением hidden
:
- display: none; — указание браузеру скрыть элемент, убрав его из общего потока элементов. В этом случае элемент, расположенный после скрытого элемента, будет смещаться вверх, занимая место скрытого элемента.
- visibility: hidden; — указание браузеру скрыть элемент, зарезервировав под него место на веб-странице. В этом случае браузер только скрывает элемент, не удаляя его из общего потока, поэтому на месте скрытого элемента останется пустое пространство, совпадающее по размеру с размером скрытого элемента.
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title>Название документа</title> <style> h2.hidden { visibility: hidden; } h3.none { display: none; } </style> </head> <body> <h2>Это видимый заголовок</h2> <h2>Скрытый заголовок</h2> <h3>Скрытый заголовок2</h3> <p>Элемент, который скрыт с помощью свойства visibility, все равно занимает пространство там, где он должен находиться в отличие от элемента скрытого с помощью свойства display, который убран из общего потока страницы.</p> </body> </html>Попробовать »
основные способы — учебник CSS
В CSS существует несколько способов скрыть элемент. При этом скрытие может быть как полным, так и чисто визуальным. Разберем по порядку каждый вариант.
Скрытие элемента с помощью opacity: 0
Если быть точным, свойство opacity
не скрывает элемент, а лишь определяет его степень прозрачности. Значение 1
означает полную непрозрачность объекта, а значение 0
, соответственно, приводит к полной прозрачности, в результате чего элемент перестает быть виден для посетителя. Последняя часть предложения важна: элемент будет скрыт лишь визуально, но при этом он будет занимать свое место на странице, влиять на положение других элементов, и с ним можно будет взаимодействовать (к примеру, он станет непрозрачным при наведении мыши, если определить соответствующий стиль для состояния :hover
). Скрин-ридеры также будут видеть данный элемент.
Преимуществом свойства opacity
является его совместимость с transition
. Это значит, что можно заставить элемент изменять свою прозрачность плавно, а не рывком. Тем самым можно создать красивое появление элемента.
В отличие от свойства прозрачности, свойство visibility
специально предназначено для визуального скрытия элементов. Значение hidden
скрывает элемент, а значение visible
— показывает. Как и в случае с opacity
, элемент продолжает занимать свое место на странице, однако взаимодействовать с элементом, скрытым с помощью visibility: hidden
, нельзя. Скрин-ридеры не видят такой элемент.
Свойство visibility
не реагирует на свойство transition
, а это означает, что изменение значения с hidden
на visible
(либо наоборот) будет происходить мгновенно.
На практике для временного скрытия элементов часто используется два свойства сразу — visibility
и opacity
(в одном из практических уроков мы уже показывали этот прием). При этом убивается сразу несколько зайцев: с помощью visibility
элемент скрывается как положено (в т. ч. от скрин-ридеров), а с помощью opacity
обеспечивается плавное появление элемента в необходимый момент.
Скрытие элемента с помощью display: none
Свойство display
со значением none стоит использовать в том случае, если вам нужно полностью скрыть элемент. Такой объект (и все его дочерние элементы) не только перестает быть виден посетителю и скрин-ридеру, но и не занимает места на странице и не влияет на расположение других элементов. Всё выглядит так, словно элемента и нет. Естественно, взаимодействовать с элементом, который скрыт данным образом, тоже невозможно.
Как и в случае со свойством visibility
, свойство display
не поддерживает плавные переходы transition
.
Скрытие элемента с помощью position: absolute
Еще один способ скрыть элемент исключительно визуально — задать ему абсолютное позиционирование, выдернув из общего потока документа, и затем переместить далеко за пределы видимой области путем установки больших отрицательных значений для свойств top
и left
. Например:
div { position: absolute; top: -9999px; left: -9999px; }
Логично предположить, что спрятать таким образом элемент от скрин-ридеров нельзя, да и в целом не рекомендуется применять этот вариант скрытия, поскольку есть более надежные и правильные способы, описанные выше. Однако в некоторых нетривиальных ситуациях веб-разработчики всё же используют его.
Далее в учебнике: CSS Grid Layout — будущее уже здесь.
Ещё четыре способа скрыть и показать элементы при помощи HTML и CSS — CSS-LIVE
Перевод статьи Four More Ways To Hide & Show Elements with HTML and CSS с сайта demosthenes.info, c разрешения автора — Дадли Стори.
Приквел к этой статье – «Четыре способа заставить элементы исчезнуть (и появиться) при помощи CSS» – был сосредоточен на классических техниках для скрытия элементов на странице; на этот раз используются методы, которые работают в современных браузерах, с некоторыми ограничениями для IE. Используется разметка, которая похожа на разметку из предыдущего примера:
<figure id="oymyakon"> <img src="nastya.jpeg" alt> <figcaption>Nastya, photographed by Sean Archer
</figcaption> </figure> <p>Located deep in Siberia, the village of Oymyakon holds the title of the coldest permanently inhabited place on Earth, tied with Verkhoyansk.
<p>From December to February, the weather in the tiny village (population 500) plummets to -50°F (-45C), with a record low of -90°F (-68C) registered in 1933. At those temperatures, a naked human left outside would freeze to death in under a minute…
CSS будет таким:
body { color:#fff
; background: url(px.png)#333
; line-height:1.4
; font-size:1.1rem
; } figure#oymyakon { float:right
; width:50%
; font-size:0
; } figure#oymyakon img { width:100%
; height:auto
; box-shadow:0 0 12px rgba(0,0,0,.3)
; } figure#oymyakon figcaption { text-align:center
; font-size:1rem
; font-style:italic
; margin-top:1rem
; }
В этой статье я применяю разные техники для скрытия элемента <figure>: можно протестировать эти методы в интерактивном примере в начале оригинальной статьи или перейдя по этой ссылке на CodePen.
Масштабирование элемента в 0
figure#oymyakon { transform:scale
(0)
; }
Очевидно, если вы делаете что-то бесконечно маленьким, это «что-то» в итоге исчезнет. Стоит отменить, что изначальная область элемента сохранится, потому что действие трансформации по сути похоже на поведение элемента с position: relative
;
Возврат значения scale
в значение 1
заставит элемент появиться снова; этот переход также может быть анимирован.
Минусы: Поддерживается во всех современных браузерах, но только начиная с IE9+. Нельзя применять к строчным элементам. Для старых версий браузеров требуются префиксы.
<figure id="oymyakon" hidden>
Хотя визуально он действует так же, как display: none
, этот элемент фиксирует состояние элемента
При установке элементу, hidden
указывает, что элемент еще не имеет или уже не имеет непосредственного отношения к текущему состоянию страницы.
Атрибут hidden
уже используется для таких HTML5-элементов, как details
. В отличие от других описанных здесь методов, атрибут hidden
скрывает элемент от любых способов представления, включая печать, мобильные и скринридеры. Поддерживается всеми современными браузерами, за исключениями одного.
Минусы: Всё ещё не поддерживается в IE, хотя это легко решается в CSS при помощи селектора по атрибуту:
[hidden] { display: none
; }
figure#oymyakon { height:0
; overflow:hidden
; }
Традиционное решение. Фактически «схлопывает» элемент по вертикали и делает его невидимым; работает при условии, что у элемента нет видимой границы. Стоит отметить, что некоторое пространство на странице для скрытого элемента, вероятно, будет «забронировано»: несмотря на то, что у элемента нет высоты, у него всё ещё есть ширина и, возможно, поле, которые могут продолжать влиять на макет страницы.
Минусы: Не применяется к строчным элементам. Значение height
не может быть анимировано, хотя max
-
height
может.
Фильтр размытия
figure#oymyakon { filter:blur
(100
px
)
; }
Новейший подход, который вообще не будет работать в IE (по крайней мере на данный момент). И всё же blur
– интересный вариант, который стоит рассмотреть на будущее.. Достаточное размытие делает элемент полностью невидимым, а при уменьшении значения blur
до 0
элемент снова оказывается «в фокусе»
Соображения:
- размытие небольшого текста работает лучше чем изображения
- Размытые изображения могут добавить оставшейся части страницы оттенок цвета, в зависимости от их относительного размера и значения
blur
. - Чем выше значение
blur
, тем больше требуется вычислительных циклов для его достижения; достаточно высокие значения могут существенно загрузить графический процессор, что делает эту технику нецелесообразной для мобильных устройств на данный момент. - Поддерживается только в последней версии Firefox (35 версия – прим. перев.) (хотя есть возможность использовать SVG в качестве запасного варианта)
- Всё ещё требует браузерных префиксов для Chrome и Safari.
- Как уже было указано, не будет работать ни в каких версиях IE.
С этими и другими методами, рассмотренными в прошлой статье, у вас есть полный набор инструментов для создания элементов, которые появляются и исчезают на странице. Важно понимать, что не существует единственной «правильной» или «лучшей» техники: бывает лишь наиболее подходящий инструмент для конкретной задачи. Это относится и к JavaScript, у которого есть собственные методы для добавления и удаления элементов в DOM.
P.S. Это тоже может быть интересно: