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