Растянутая ссылка
Сделайте любой HTML-элемент или компонент Bootstrap кликабельным, «растягивая» вложенную ссылку с помощью CSS.
Добавьте .stretched-link к ссылке, чтобы сделать ее содержащий блок доступным для кликов через псевдоэлемент ::after. В большинстве случаев это означает, что элемент с position: relative;, который содержит ссылку с классом .stretched-link, является интерактивным. Обратите внимание, учитывая как работает CSS position, .stretched-link нельзя смешивать с большинством элементов таблицы.
Карточки имеют в Bootstrap по умолчанию position: relative, поэтому в этом случае Вы можете безопасно добавить класс .stretched-link к ссылке в карточке без каких-либо других изменений HTML.
При растянутых ссылках не рекомендуется использовать несколько ссылок и целей касания. Однако некоторые стили position и z-index могут помочь, если это потребуется.
Карточка с растянутой ссылкой
Небольшой пример текста, основанного на названии карты и составляющего основную часть содержимого карты.
Перейти куда-нибудь<divclass="card"style="width: 18rem;"><imgsrc="..."class="card-img-top"alt="..."><divclass="card-body"><h5class="card-title">Карточка с растянутой ссылкой</h5><pclass="card-text">Небольшой пример текста, основанного на названии карты и составляющего основную часть содержимого карты.</p><ahref="#"class="btn btn-primary stretched-link">Перейти куда-нибудь</a></div></div>Большинство пользовательских компонентов по умолчанию не имеют position: relative, поэтому нам нужно добавить сюда .position-relative, чтобы предотвратить растяжение ссылки за пределы родительского элемента.
Пользовательский компонент с растянутой ссылкой
Это некий заполнитель для пользовательского компонента. Он предназначен для имитации того, как будет выглядеть реальный контент, и мы используем его здесь, чтобы придать компоненту немного тела и размера.
Иди куда-нибудь<divclass="d-flex position-relative"><imgsrc="..."class="flex-shrink-0 me-3"alt="..."><div><h5class="mt-0">Пользовательский компонент с растянутой ссылкой</h5><p>Это некий заполнитель для пользовательского компонента. Он предназначен для имитации того, как будет выглядеть реальный контент, и мы используем его здесь, чтобы придать компоненту немного тела и размера.</p><ahref="#"class="stretched-link">Иди куда-нибудь</a></div></div>Столбцы с растянутой ссылкой
Другой экземпляр содержимого-заполнителя для этого другого настраиваемого компонента. Он предназначен для имитации того, как будет выглядеть реальный контент, и мы используем его здесь, чтобы придать компоненту немного тела и размера.
Иди куда-нибудь<divclass="row g-0 bg-body-secondary position-relative"><divclass="col-md-6 mb-md-0 p-md-4"><imgsrc="..."class="w-100"alt="..."></div><divclass="col-md-6 p-4 ps-md-0"><h5class="mt-0">Столбцы с растянутой ссылкой</h5><p>Другой экземпляр содержимого-заполнителя для этого другого настраиваемого компонента. Он предназначен для имитации того, как будет выглядеть реальный контент, и мы используем его здесь, чтобы придать компоненту немного тела и размера.</p><ahref="#"class="stretched-link">Иди куда-нибудь</a></div></div>Идентификация содержащего блока
Если растянутая ссылка не работает, вероятно, причиной будет содержащий блок. Следующие свойства CSS сделают элемент содержащим блоком:
- Значение
position, отличное отstatic - Значение
transformилиperspective, отличное отnone - Значение
will-changeизtransformилиperspective - Значение
filter, отличное отnoneили значениеwill-changeизfilter(работает только в Firefox)
Карточка с растянутыми ссылками
Небольшой пример текста, основанного на названии карты и составляющего основную часть содержимого карточки.
Растянутая ссылка здесь не будет работать, потому что к ссылке добавляется position: relative
Эта растянутая ссылка будет распространяться только на тег p, поскольку к ней применяется преобразование.
<divclass="card"style="width: 18rem;"><imgsrc="..."class="card-img-top"alt="..."><divclass="card-body"><h5class="card-title">Карточка с растянутыми ссылками</h5><pclass="card-text">Небольшой пример текста, основанного на названии карты и составляющего основную часть содержимого карточки.</p><pclass="card-text"><ahref="#"class="stretched-link text-danger"style="position: relative;">Растянутая ссылка здесь не будет работать, потому что к ссылке добавляется <code>position: relative</code></a></p><pclass="card-text bg-body-tertiary"style="transform: rotate(0);"> Эта <ahref="#"class="text-warning stretched-link">растянутая ссылка</a> будет распространяться только на тег <code>p</code>, поскольку к ней применяется преобразование.
</p></div></div>