Уменьшите размер фона текстового поля, используя bootstrap карусель - PullRequest
0 голосов
/ 19 февраля 2020

Я использую Bootstrap 4.0 и класс карусели. У меня есть подпись для каждого изображения, которое является частью карусели, и я хотел бы уменьшить ширину фона подписи, поскольку он шире, чем текст. (см. желтые стрелки ниже) Picture of oversizes background Я использовал различные bootstrap классы, такие как d-md-flex, но он перемещает текстовое поле влево влево.

Как можно Уменьшить ширину фона? Текст не является динамическим c, поэтому, хотя было бы предпочтительным иметь параметр flex, я могу использовать фиксированную или максимальную ширину. Это должно быть в центре, хотя.

Спасибо!

<div class="carousel-item">
  <img class="d-block w-100" src="img/t/flowers.svg" alt="Creativity">
  <div class="carousel-caption d-none d-md-block text-dark">
    <h1 style="background-color: rgba(250, 250, 250,0.5);">Everyday Creativity</h1>
  </div>
</div>

Ответы [ 2 ]

1 голос
/ 19 февраля 2020

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

рабочий фрагмент ниже:

.carousel-inner img {
  width: 100%;
  height: 100%;
}

.carousel-caption h1 {
  width: fit-content;
  margin: auto;
}
<link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/4.4.1/css/bootstrap.min.css">
<script src="https://ajax.googleapis.com/ajax/libs/jquery/3.4.1/jquery.min.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/popper.js/1.16.0/umd/popper.min.js"></script>
<script src="https://maxcdn.bootstrapcdn.com/bootstrap/4.4.1/js/bootstrap.min.js"></script>

<div id="demo" class="carousel slide" data-ride="carousel">

  <!-- Indicators -->
  <ul class="carousel-indicators">
    <li data-target="#demo" data-slide-to="0" class="active"></li>
    <li data-target="#demo" data-slide-to="1"></li>
    <li data-target="#demo" data-slide-to="2"></li>
  </ul>

  <!-- The slideshow -->
  <div class="carousel-inner">
    <div class="carousel-item active">
      <img src="https://www.w3schools.com/bootstrap4/la.jpg" alt="Los Angeles" width="1100" height="500">
      <div class="carousel-caption d-none d-md-block text-dark">
        <h1 style="background-color: rgba(250, 250, 250,0.5);">Everyday</h1>
      </div>
    </div>
    <div class="carousel-item">
      <img src="https://www.w3schools.com/bootstrap4/chicago.jpg" alt="Chicago" width="1100" height="500">
      <div class="carousel-caption d-none d-md-block text-dark">
        <h1 style="background-color: rgba(250, 250, 250,0.5);">Everyday Creativity</h1>
      </div>
    </div>
    <div class="carousel-item">
      <img src="https://www.w3schools.com/bootstrap4/ny.jpg" alt="New York" width="1100" height="500">
      <div class="carousel-caption d-none d-md-block text-dark">
        <h1 style="background-color: rgba(250, 250, 250,0.5);">Everyday Creativity, Everyday </h1>
      </div>
    </div>
  </div>

  <!-- Left and right controls -->
  <a class="carousel-control-prev" href="#demo" data-slide="prev">
    <span class="carousel-control-prev-icon"></span>
  </a>
  <a class="carousel-control-next" href="#demo" data-slide="next">
    <span class="carousel-control-next-icon"></span>
  </a>
</div>
0 голосов
/ 19 февраля 2020

вы можете уменьшить width из h1 до его содержимого через max-content или display:table; для старых браузеров:

body {background:tomato;}
<code>max-content</code><h1 style="background-color: rgba(250, 250, 250,0.5);margin:1em auto;width:max-content;">Everyday Creativity</h1>
<code>display:table;</code><h1 style="background-color: rgba(250, 250, 250,0.5);margin:1em auto;display:table;">Everyday Creativity</h1>

информация:

...