Перейти к основному содержанию Перейти к навигации по документам
Check
Cмотреть на GitHub

Растянутая ссылка

Сделайте любой HTML-элемент или компонент Bootstrap кликабельным, «растягивая» вложенную ссылку с помощью CSS.

Добавьте .stretched-link к ссылке, чтобы сделать ее содержащий блок доступным для кликов через псевдоэлемент ::after. В большинстве случаев это означает, что элемент с position: relative;, который содержит ссылку с классом .stretched-link, является интерактивным. Обратите внимание, учитывая как работает CSS position, .stretched-link нельзя смешивать с большинством элементов таблицы.

Карточки имеют в Bootstrap по умолчанию position: relative, поэтому в этом случае Вы можете безопасно добавить класс .stretched-link к ссылке в карточке без каких-либо других изменений HTML.

При растянутых ссылках не рекомендуется использовать несколько ссылок и целей касания. Однако некоторые стили position и z-index могут помочь, если это потребуется.

Card image cap
Карточка с растянутой ссылкой

Небольшой пример текста, основанного на названии карты и составляющего основную часть содержимого карты.

Перейти куда-нибудь
html
<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, чтобы предотвратить растяжение ссылки за пределы родительского элемента.

Общее изображение-заглушка
Пользовательский компонент с растянутой ссылкой

Это некий заполнитель для пользовательского компонента. Он предназначен для имитации того, как будет выглядеть реальный контент, и мы используем его здесь, чтобы придать компоненту немного тела и размера.

Иди куда-нибудь
html
<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>
Общее изображение-заглушка
Столбцы с растянутой ссылкой

Другой экземпляр содержимого-заполнителя для этого другого настраиваемого компонента. Он предназначен для имитации того, как будет выглядеть реальный контент, и мы используем его здесь, чтобы придать компоненту немного тела и размера.

Иди куда-нибудь
html
<div class="row g-0 bg-light 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 сделают элемент содержащим блок:

  • A position отличное от static
  • A transform или perspective отличное от none
  • A will-change значение transform или perspective
  • A filter отличное от none или will-change изменяющее filter (работает только в Firefox)
Заглушка изображения карточки
Карточка с растянутыми ссылками

Небольшой пример текста, основанного на названии карты и составляющего основную часть содержимого карточки.

Растянутая ссылка здесь не будет работать, потому что к ссылке добавляется position: relative

Эта растянутая ссылка будет распространяться только на тег p, поскольку к ней применяется преобразование.

html
<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-light" style="transform: rotate(0);">
      Эта <a href="#" class="text-warning stretched-link">растянутая ссылка</a> будет распространяться только на тег <code>p</code>, поскольку к ней применяется преобразование.
    </p>
  </div>
</div>