קישור מתוח
הפוך כל רכיב HTML או רכיב Bootstrap לניתנים ללחיצה על ידי "מתיחת" קישור מקונן באמצעות CSS.
הוסף .stretched-linkלקישור כדי להפוך את החסימה המכילה שלו לניתנת ללחיצה באמצעות ::afterאלמנט פסאודו. ברוב המקרים, זה אומר שרכיב עם position: relative;זה מכיל קישור עם .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">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>
לאובייקטי מדיה אין position: relativeכברירת מחדל, לכן עלינו להוסיף את ה- .position-relativeכאן כדי למנוע מהקישור להימתח מחוץ לאובייקט המדיה.
מדיה עם קישור מתוח
Cras sit amet nibh libero, in gravida nulla. Nulla vel metus scelerisque ante sollicitudin. Cras purus odio, vestibulum in vulputate at, tempus viverra turpis. Fusce condimentum nunc ac nisi vulputate fringilla. Donec lacinia congue felis ב-faucibus.
ללכת לאנשהו<div class="media position-relative">
<img src="..." class="mr-3" alt="...">
<div class="media-body">
<h5 class="mt-0">Media with stretched link</h5>
<p>Cras sit amet nibh libero, in gravida nulla. Nulla vel metus scelerisque ante sollicitudin. Cras purus odio, vestibulum in vulputate at, tempus viverra turpis. Fusce condimentum nunc ac nisi vulputate fringilla. Donec lacinia congue felis in faucibus.</p>
<a href="#" class="stretched-link">Go somewhere</a>
</div>
</div>
עמודות הן position: relativeכברירת מחדל, כך שעמודות הניתנות ללחיצה דורשות רק את .stretched-linkהמחלקה בקישור. עם זאת, מתיחת קישור על פני שלם .rowדורשת .position-staticעל העמודה ועל .position-relativeהשורה.
עמודות עם קישור מתוח
Cras sit amet nibh libero, in gravida nulla. Nulla vel metus scelerisque ante sollicitudin. Cras purus odio, vestibulum in vulputate at, tempus viverra turpis. Fusce condimentum nunc ac nisi vulputate fringilla. Donec lacinia congue felis ב-faucibus.
ללכת לאנשהו<div class="row no-gutters 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 position-static p-4 pl-md-0">
<h5 class="mt-0">Columns with stretched link</h5>
<p>Cras sit amet nibh libero, in gravida nulla. Nulla vel metus scelerisque ante sollicitudin. Cras purus odio, vestibulum in vulputate at, tempus viverra turpis. Fusce condimentum nunc ac nisi vulputate fringilla. Donec lacinia congue felis in faucibus.</p>
<a href="#" class="stretched-link">Go somewhere</a>
</div>
</div>
זיהוי הבלוק המכיל
אם נראה שהקישור המתוח לא עובד, כנראה שהגוש המכיל יהיה הגורם. מאפייני ה-CSS הבאים יהפכו אלמנט לבלוק המכיל:
- ערך
positionאחר מאשרstatic - A
transformאוperspectiveערך אחר מאשרnone - ערך
will-changeשלtransformאוperspective - ערך
filterשונהnoneאוwill-changeערך שלfilter(עובד רק בפיירפוקס)
כרטיס עם קישורים מתוחים
טקסט דוגמה מהיר לבניית כותרת הכרטיס ולהוות את עיקר התוכן של הכרטיס.
קישור מתוח לא יעבוד כאן, כי position: relativeהוא נוסף לקישור
הקישור המתוח הזה יתפזר רק על פני pהתג - מכיוון שהוחל עליו טרנספורמציה.
<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>