Чем left: -999999px лучше, чем display:none ?

При верстке всяких табов и прочего почему используют прятки за экран, а не дисплей нон?
  • Вопрос задан
  • 3183 просмотра
Пригласить эксперта
Ответы на вопрос 7
DeLaVega
@DeLaVega
Верстаю, фронтэндю =)
display: none - нельзя плавно показать одним css-ом, в отличие от left.
Ответ написан
Комментировать
Lynn
@Lynn
nginx, js, css
Первоначально этот трюк предназначался для экранных читалок. Текст скрытый через display: none они не видят, а сдвинутый за экран без проблем читают.

У нас до сих пор не принято обращать внимание на доступность сайта слепым и прочим инвалидам, а на западе это практически обязательно.
Ответ написан
Комментировать
BuriK666
@BuriK666
Компьютерный псих
Если display:none, background-image и прочие картинки не будут загружены, пока элемент не станет видимым.
Ответ написан
Почему вы решили, что он лучше и если он действительно лучше, почему большинство разработчиков используют display:none?

Был неправ, сегодня столкнулся с интересной особенностью браузера firefox (на других не проявляется): В спрятанном display:none блоке функция MatchMedia возвращает null, для блока с left:-999999 все нормально. В частности, реализовал проект, на котором видео с ютуба должно было запускаться после нажатия кнопки и появления ранее невидимого блока на экране. В файрфоксе в невидимом блоке инициализация объекта с видео не происходит и вместо него лишь черный экран (в других браузерах все ок). Переписывание стилей с display:none на left:-99999 решило проблему. Также подобное описывается тут stackoverflow.com/questions/12056313/matchmedia-re..., поэтому в редких случаях хак с left имеет право быть, но только в редких случаях.
Ответ написан
Комментировать
left удобно использовать когда элемент должен иметь несколько позиций в зависимости от чего-либо (оригинальной идеи, размера окна и тд.)
Ответ написан
Комментировать
Finorion
@Finorion
Верстальщик
При использовании display:none, в резиновой верстке, будет сложнее через js получить размер скрытых изображений.
Ответ написан
Комментировать
gene4000
@gene4000
По разным причинам, так навскидку и не вспомнишь. Но могу подкинуть еще способ с visibility. Тоже иногда полезно (а иногда необходимо для некоторых браузеров).
Ответ написан
Комментировать
Ваш ответ на вопрос

Войдите, чтобы написать ответ

Похожие вопросы
22 нояб. 2024, в 03:54
1500 руб./за проект
22 нояб. 2024, в 02:56
10000 руб./за проект
22 нояб. 2024, в 00:55
500 руб./за проект