Source

קישור מתוח

הפוך כל רכיב HTML או רכיב Bootstrap לניתנים ללחיצה על ידי "מתיחת" קישור מקונן באמצעות CSS.

הוסף .stretched-linkלקישור כדי להפוך את החסימה המכילה שלו לניתנת ללחיצה באמצעות ::afterאלמנט פסאודו. ברוב המקרים, זה אומר שרכיב עם position: relative;זה מכיל קישור עם .stretched-linkהמחלקה ניתן ללחוץ.

לכרטיסים יש position: relativeכברירת מחדל ב-Bootstrap, כך שבמקרה זה אתה יכול להוסיף בבטחה את .stretched-linkהמחלקה לקישור בכרטיס ללא שינויים אחרים ב-HTML.

קישורים מרובים ויעדי הקשה אינם מומלצים עם קישורים מתוחים. עם זאת, כמה positionוסגנונות z-indexיכולים לעזור אם הדבר יידרש.

Card image cap
כרטיס עם קישור מתוח

טקסט דוגמה מהיר לבניית כותרת הכרטיס ולהוות את עיקר התוכן של הכרטיס.

ללכת לאנשהו
<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כאן כדי למנוע מהקישור להימתח מחוץ לאובייקט המדיה.

Generic placeholder image
מדיה עם קישור מתוח

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השורה.

Generic placeholder image
עמודות עם קישור מתוח

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(עובד רק בפיירפוקס)
Card image cap
כרטיס עם קישורים מתוחים

טקסט דוגמה מהיר לבניית כותרת הכרטיס ולהוות את עיקר התוכן של הכרטיס.

קישור מתוח לא יעבוד כאן, כי 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>