Natažený odkaz
Udělejte klikací na jakýkoli prvek HTML nebo komponentu Bootstrap „roztažením“ vnořeného odkazu pomocí CSS.
Přidat .stretched-link
k odkazu, aby bylo možné kliknout na blok, který obsahuje::after
, prostřednictvím pseudo prvku. Ve většině případů to znamená, že na prvek position: relative;
, který obsahuje odkaz na .stretched-link
třídu, lze kliknout. Upozorňujeme, že vzhledem k tomu, jak CSS position
funguje , .stretched-link
nelze jej kombinovat s většinou prvků tabulky.
Karty mají position: relative
ve výchozím nastavení Bootstrap, takže v tomto případě můžete .stretched-link
třídu bezpečně přidat do odkazu na kartě bez dalších změn HTML.
U roztažených odkazů se nedoporučuje používat více odkazů a cílů klepnutí. Nicméně, některé position
a z-index
styly mohou pomoci, pokud je to požadováno.
Karta s nataženým odkazem
Několik rychlých příkladů textu, který bude stavět na názvu karty a tvoří většinu obsahu karty.
Jít někam<div class="card" style="width: 18rem;">
<img src="..." class="card-img-top" alt="...">
<div class="card-body">
<h5 class="card-title">Card with stretched link</h5>
<p class="card-text">Some quick example text to build on the card title and make up the bulk of the card's content.</p>
<a href="#" class="btn btn-primary stretched-link">Go somewhere</a>
</div>
</div>
Většina vlastních komponent ve výchozím nastavení nemá position: relative
, takže musíme přidat .position-relative
sem, aby se zabránilo roztažení odkazu mimo nadřazený prvek.
Vlastní komponenta s nataženým odkazem
Toto je nějaký zástupný obsah pro vlastní komponentu. Je určen k napodobování toho, jak by vypadal nějaký obsah ze skutečného světa, a my jej zde používáme, abychom komponentě dodali trochu těla a velikosti.
Jít někam<div class="d-flex position-relative">
<img src="..." class="flex-shrink-0 me-3" alt="...">
<div>
<h5 class="mt-0">Custom component with stretched link</h5>
<p>This is some placeholder content for the custom component. It is intended to mimic what some real-world content would look like, and we're using it here to give the component a bit of body and size.</p>
<a href="#" class="stretched-link">Go somewhere</a>
</div>
</div>
Sloupky s nataženým článkem
Další instance obsahu zástupného symbolu pro tuto další vlastní komponentu. Je určen k napodobování toho, jak by vypadal nějaký obsah ze skutečného světa, a my jej zde používáme, abychom komponentě dodali trochu těla a velikosti.
Jít někam<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">Columns with stretched link</h5>
<p>Another instance of placeholder content for this other custom component. It is intended to mimic what some real-world content would look like, and we're using it here to give the component a bit of body and size.</p>
<a href="#" class="stretched-link">Go somewhere</a>
</div>
</div>
Identifikace obsahujícího bloku
Pokud se zdá, že natažený odkaz nefunguje, příčinou bude pravděpodobně blok, který obsahuje . Následující vlastnosti CSS udělají z prvku blok obsahující:
- Jiná
position
hodnota nežstatic
- A
transform
neboperspective
jiná hodnota nežnone
- Hodnota nebo
will-change
_transform
perspective
- Jiná
filter
hodnota nežnone
nebowill-change
hodnotafilter
(funguje pouze ve Firefoxu)
Karta s nataženými odkazy
Několik rychlých příkladů textu, který bude stavět na názvu karty a tvoří většinu obsahu karty.
Natažený odkaz zde nebude fungovat, protože position: relative
je přidán do odkazu
Tento roztažený odkaz bude rozprostřen pouze přes p
-tag, protože je na něj aplikována transformace.
<div class="card" style="width: 18rem;">
<img src="..." class="card-img-top" alt="...">
<div class="card-body">
<h5 class="card-title">Card with stretched links</h5>
<p class="card-text">Some quick example text to build on the card title and make up the bulk of the card's content.</p>
<p class="card-text">
<a href="#" class="stretched-link text-danger" style="position: relative;">Stretched link will not work here, because <code>position: relative</code> is added to the link</a>
</p>
<p class="card-text bg-light" style="transform: rotate(0);">
This <a href="#" class="text-warning stretched-link">stretched link</a> will only be spread over the <code>p</code>-tag, because a transform is applied to it.
</p>
</div>
</div>