Cмотреть на GitHub

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

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

Как это устроено

Добавьте .stretched-link к ссылке, чтобы сделать ее содержащий блок кликабельным через псевдоэлемент ::after. В большинстве случаев это означает, что элемент с position: relative;; который содержит ссылку с классом .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="media position-relative"><imgsrc="..."class="mr-3"alt="..."><divclass="media-body"><h5class="mt-0">Медиа с растянутой ссылкой</h5><p>Это некий заполнитель для медиа-объекта. Он предназначен для имитации того, как будет выглядеть реальный контент, и мы используем его здесь, чтобы придать компоненту немного тела и размера.</p><ahref="#"class="stretched-link">Иди куда-нибудь</a></div></div>

Столбцы по умолчанию являются position: relative, поэтому для интерактивных столбцов требуется только класс .stretched-link для ссылки. Однако для растягивания ссылки на весь .row требуется .position-static для столбца и .position-relative для строки.

Общее изображение-заполнитель
Столбцы с растянутой ссылкой

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

Иди куда-нибудь
<divclass="row no-gutters bg-light position-relative"><divclass="col-md-6 mb-md-0 p-md-4"><imgsrc="..."class="w-100"alt="..."></div><divclass="col-md-6 position-static p-4 pl-md-0"><h5class="mt-0">Столбцы с растянутой ссылкой</h5><p>Другой экземпляр содержимого-заполнителя для этого другого настраиваемого компонента. Он предназначен для имитации того, как будет выглядеть реальный контент, и мы используем его здесь, чтобы придать компоненту немного тела и размера.</p><ahref="#"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)
Заглушка изображения карты
Карточка с растянутой ссылкойs

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

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

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

<divclass="card"style="width: 18rem;"><imgsrc="..."class="card-img-top"alt="..."><divclass="card-body"><h5class="card-title">Карточка с растянутой ссылкойs</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-light"style="transform: rotate(0);"> Эта <ahref="#"class="text-warning stretched-link">растянутая ссылка</a> будет распространяться только на тег <code>p</code>, поскольку к ней применяется преобразование. </p></div></div>