使用 bootstrap 旋转木马减小文本框背景的大小
Decrease the size of the background of a text box using bootstrap carousel
我正在使用 Bootstrap 4.0 和轮播 class。我为轮播中的每个图像都有一个标题,并且想减少标题背景的宽度,因为它比文本宽。 (见下面的黄色箭头) 我使用了不同的 bootstrap class,例如 d-md-flex,但它会将整个文本框向左移动。
如何减小背景的宽度?文本不是动态的,所以虽然最好有一个 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>
因此我们需要将文本居中对齐,宽度仅根据内容的宽度...
下面的工作代码段:
.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>
对于旧版浏览器,您可以通过 max-content
或 display:table;
将 h1
的 width
减少到其内容:
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>
信息:
我正在使用 Bootstrap 4.0 和轮播 class。我为轮播中的每个图像都有一个标题,并且想减少标题背景的宽度,因为它比文本宽。 (见下面的黄色箭头)
如何减小背景的宽度?文本不是动态的,所以虽然最好有一个 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>
因此我们需要将文本居中对齐,宽度仅根据内容的宽度...
下面的工作代码段:
.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>
对于旧版浏览器,您可以通过 max-content
或 display:table;
将 h1
的 width
减少到其内容:
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>
信息: