Тег details
Тег details создает спойлер на HTML, то есть используется для информации, которую можно скрыть или показать по желанию пользователя.
По умолчанию содержимое тега скрыто, для его показа по требованию пользователя следует добавить тег summary, который указывает заголовок для тега details . Этот заголовок всегда виден на странице (даже если содержимое details находится в свернутом состоянии) и по нему можно щелкать для разворачивания скрытого текста или сворачивания.
Так же для показа скрытого содержимого можно использовать атрибут open тега details (например, для показа содержимого details с помощью JavaScript).
Пример
Давайте посмотрим, как работает тег details :
Спойлер HTML: теги и
– Потому, – ответил иностранец и прищуренными глазами поглядел в небо, где, предчувствуя вечернюю прохладу, бесшумно чертили черные птицы, – что Аннушка уже купила подсолнечное масло, и не только купила, но даже разлила.
details < display: inline;/* текст на текущей строке */ > details[open] < display: contents;/* спрятанный текст на текущей строке (в Google Chrome отсутствует реализация на момент написания статьи) */ > details summary < list-style-type: "[. ]";/* такие слова, как «Ещё», «Читать дальше», «Нажать» лучше вносить в list-style-type, чтобы они не были видны в браузерах, не поддерживающих тег details (в Google Chrome отсутствует реализация на момент написания статьи) */ color: blue; cursor: pointer; > details[open] summary Текстскрытое/показанное содержимое
В ряде браузеров нельзя сделать inline-элементом
Текст до тега
.
ТекстТекстМетка
скрытое/показанное содержимое
Вложенный в тег
Нажать [Закрыть] скрытое/показанное содержимое
details:not([open]) summary small display: none; > details[open] summary smallНажать [Закрыть] скрытое/показанное содержимое
Ссылка внутри
- position static;
- position: relative;
- position: absolute;
- position: fixed;
- position: sticky;
Сделать плавное открытие и скрытие блока при нажатии
Не получается анимировать блок, когда тот сворачивается. В Mozilla Firefox при display: contents; элемент
скрытое/показанное содержимое
Первая цитата
— Это водка? — слабо спросила Маргарита.
Кот подпрыгнул на стуле от обиды.
— Помилуйте, королева, — прохрипел он, — разве я позволил бы себе налить даме водки? Это чистый спирт!
Вторая цитата
Свежесть бывает только одна — первая, она же и последняя. А если осетрина второй свежести, то это означает, что она тухлая!
Третья цитата
— Вы не Достоевский, — сказала гражданка, сбиваемая с толку Коровьевым.
— Ну, почем знать, почем знать, — ответил тот.
— Достоевский умер, — сказала гражданка, но как-то не очень уверенно.
— Протестую, — горячо воскликнул Бегемот. — Достоевский бессмертен!
Заголовок 1 Содержимое 1Заголовок 2
Содержимое 2
Блок раскрывается при щелчке по кнопке, а не по всей строке
Нажать скрытое/показанное содержимое
details summary < width: -webkit-fit-content; width: -moz-fit-content; width: fit-content;transition: color .3s; /* плавная смена цвета */ cursor: pointer; /* изменение курсора при наведении */ > details summary:hover, details[open] summaryНажать
скрытое/показанное содержимое
Текст «открыть/закрыть» при развёртывании и свёртывании содержимого
скрытое/показанное содержимое
скрытое/показанное содержимое
Поменять стрелочку на знаки плюс и минус
Нажать Первый способ
Нажать
скрытое/показанное содержимое
Нажать Второй способ
Нажать
скрытое/показанное содержимое
Код закрывающейся метки внизу блока
– Потому, – ответил иностранец и прищуренными глазами поглядел в небо, где, предчувствуя вечернюю прохладу, бесшумно чертили черные птицы, – что Аннушка уже купила подсолнечное масло, и не только купила, но даже разлила.
div < position: relative; > details, summary < display: inline; >details[open] < display: contents; >details[open]::after < /* пространство для записи "СВЕРНУТЬ" */ display: block; content: "\00a0"; > summary < color: gray; cursor: pointer; >details[open] summary < position: absolute; /* переместить запись "СВЕРНУТЬ" вниз*/ bottom: 0; left: 0; > summary::before < content: "ЕЩЁ"; >details[open] summary::before < content: "СВЕРНУТЬ"; >summary::-webkit-details-markerТекстскрытое/показанное содержимоеСделать вложенный спойлер
Cпрятать спойлер и текст под спойлер Текст Спрятать текст под спойлер Текст
details < display: block; border: 1px solid silver; border-radius: 4px; padding: .5em; >details summary < display: list-item; margin: -.5em; padding: .5em; >details[open] > summaryCпрятать спойлер и текст под спойлер
ТекстСпрятать текст под спойлер
ТекстСтилизация: красивый спойлер CSS
- Показать\скрыть текст HTML
- Раскрывающийся древовидный список
- Раскрывающаяся таблица по клику
- Модальное окно
- Табы CSS
- Accordion CSS
Спойлер
Спойлером называется раскрытие интриги, влияющее на восприятие сюжета книги или фильма. В детективах, к примеру, спойлером является имя убийцы. Чтобы не портить удовольствие от предстоящего чтения или просмотра фильма текст спойлера прячут, оставляя возможность его просмотреть тем, кто хочет узнать подробности сюжета.
![]()
В примере 1 показано использование элемента для создания спойлеров.
Пример 1. Спойлер, сделанный через
В браузерах IE и Edge элементы и не работают, текст спойлера в них отображается сразу же. Поэтому для универсальности рассмотрим альтернативную реализацию через псевдокласс :checked .
Пример 2. Структура спойлера
Внимание, спойлер!Убийца — дворецкий!Сперва прячем и текст спойлера через свойство display со значением none .
.spoiler input, .spoiler divА затем показываем его через псевдокласс :checked с помощью всё того же свойства display .
.spoiler :checked ~ divЭтого уже достаточно, чтобы при щелчке по ниже расположенный отображался и скрывался. Всё остальное это косметические детали для оформления. Добавим перед заголовком стрелку, как это реализовано в , через псевдоэлемент ::before и свойство content, значением которого будет символ стрелки, направленной вправо или вниз.
/* Закрытый спойлер */ .spoiler label::before < content: '►'; margin-right: 5px; >/* Открытый спойлер */ .spoiler :checked + label::beforeОкончательный код продемонстрирован в примере 3.
Пример 3. Спойлер, сделанный через :checked
Результат данного примера в браузере Internet Explorer показан на рис. 2.
Рис. 2. Вид спойлера
Теперь наш спойлер работает во всех основных браузерах. К недостаткам метода следует отнести громоздкий код HTML — при добавлении нескольких спойлеров каждому внутри spoiler надо давать уникальный id и это же значение затем писать в атрибуте for для .
См. также
- display
- display в CSS
- relative и absolute
- Аккордеон меню
- Блочные элементы
- Вкладки на CSS
- Выпадающее меню
- Декоративные заголовки
- Добавление тени
- Использование :checked
- Использование в вёрстке
- Не только текст
- Описание float
- Открываем блочную модель
- Подробнее о позиционировании
- Псевдокласс :checked
- Псевдоэлемент ::before
- Псевдоэлементы
- Псевдоэлементы ::after и ::before
- Создание флексбоксов
- Стилизация переключателей
- Стилизация флажков
- Стилизация элементов MathML
- Строчно-блочные элементы
- Строчные элементы
- Что это такое?
Как сделать спойлер на сайте
Hobo 2020-07-31 в Вебмастер Комментариев: 2
Последнее бновение — 15 января 2023 в 16:22
Чтобы сделать спойлер на сайте, работающем под управлением CMS WordPress, не обязательно устанавливать дополнительный плагин. Достаточно обладать навыком редактирования файлов установленной темы.
Что такое спойлер и зачем он нужен? Это некоторая часть контента на веб-странице, которая скрыта от глаз пользователя. Однако, при желании, посетитель сайта без труда имеет возможность открыть её одним кликом мышки и просмотреть. Иногда требуется скрыть некоторый контент, который не имеет особой смысловой нагрузки, либо очень длинный текст. Назначение может быть различным.
В Сети я нашёл несколько способов реализации такого функционала. В этой записи приведу несколько примеров.
Начну с варианта, предложенного ImpulsWeb. Потребуется вставить в область контента, где хотим видеть спойлер, html-код, включить в работу скрипт и присвоить стили. Кроме того, следует учитывать, что на веб-ресурсе подключена и правильно работает библиотека JQuery.
Автор предлагает такую вёрстку:
Читаете этот текст? Ура! Значит, созданный вами спойлер работает!(Этот текст можно менять по своему усмотрению)