用中心方形组件填充柔性容器

时间:2017-12-18 21:12:59

标签: html css css3 responsive-design

我尝试实现的目标如下图所示: enter image description here

外部矩形是一个div容器,可以具有任何大小和比例(它可以通过调整浏览器窗口大小调整大小),而内部是一个组件(填充在图片上),应该保持1:1的比例(正方形) ),并应集中在容器中。所以它的边用公式min(container_width, container_height)来描述。

关于如何做到这一点的任何想法?

4 个答案:

答案 0 :(得分:1)

这可以通过以下三个方面来实现:

Flexbox可用于确保内部元素水平和垂直居中。这是通过容器上只有三个不同的规则来实现的:

display: flex;
align-items: center;
justify-content: center;

使父元素具有可变宽度时使内部元素保持正方形的关键是将子元素的widthheight基于父元素的height

在下文中,我将内部正方形的widthheight放在父容器的height之外(除以4)。考虑到子项的heightwidth由与父项的--value相同的height定义,它将始终保持正方形和相称:



:root {
  --value: 200px;
}

.container {
  display: flex;
  align-items: center;
  justify-content: center;
  border: 2px solid black;
  height: var(--value);
}

.box {
  background: black;
  height: calc(var(--value) / 4);
  width: calc(var(--value) / 4);
}

<div class="container">
  <div class="box">
  </div>
</div>
&#13;
&#13;
&#13;

请注意,如果您使用 vh unit 将CSS变量置于视口高度之外,这也会有效:

&#13;
&#13;
:root {
  --value: 50vh;
}

.container {
  display: flex;
  align-items: center;
  justify-content: center;
  border: 2px solid black;
  height: var(--value);
}

.box {
  background: black;
  height: calc(var(--value) / 4);
  width: calc(var(--value) / 4);
}
&#13;
<div class="container">
  <div class="box">
  </div>
</div>
&#13;
&#13;
&#13;

希望这有帮助! :)

答案 1 :(得分:1)

我认为您可以使用以下代码实现目标。您需要将图像设置为内部div的背景,而不是直接使用<img>

&#13;
&#13;
.wrapper {
    width: 100%;
    height: 300px;
    padding: 10px;
    box-sizing: border-box;
    border: 1px solid red;
}

.inner {
    background: url('http://lorempixel.com/output/abstract-q-c-300-300-7.jpg') no-repeat center center;
    background-size: contain;
    width: 100%;
    height: 100%;
}
&#13;
<div class="wrapper">
  <div class="inner"></div>
</div>
&#13;
&#13;
&#13;

解决方案2:使用<img>并将位置设置为绝对值。

&#13;
&#13;
.wrapper {
  position: relative;
  top: 0;
  left: 0;
  width: 100%;
  height: 300px;
  border: 1px solid red;
  box-sizing: border-box;
}

.wrapper img {
  position: absolute;
  transform: translate(-50%, -50%);
  top: 50%;
  left: 50%;
  max-width: 100%;
  max-height: 100%;
}
&#13;
<div class='wrapper'>
  <img src='http://lorempixel.com/output/abstract-q-c-300-300-7.jpg'>
</div>
&#13;
&#13;
&#13;

答案 2 :(得分:1)

如果方格是这种情况下的图像,你可以这样做:

.container {
  position:relative;
  text-align: center;
  border: 1px solid;
  background:#f2f2f5;
}
img {
  position:absolute;
  top:50%;
  left:50%;
  transform:translate(-50%,-50%);
  max-height: 100%;
  max-width: 100%;
}
<div class="container" style="width:400px;height:100px;">
  <img src="https://lorempixel.com/400/400/" />
</div>
<div class="container" style="width:200px;height:400px;">
  <img src="https://lorempixel.com/400/400/" />
</div>

<div class="container" style="width:400px;height:400px;">
  <img src="https://lorempixel.com/400/400/" />
</div>
<div class="container" style="width:50px;height:600px;">
  <img src="https://lorempixel.com/400/400/" />
</div>
<div class="container" style="width:600px;height:50px;">
  <img src="https://lorempixel.com/400/400/" />
</div>

使用100%高度时需要注意,因为这取决于容器的,如果没有指定高度将为0,因此图像也是如此:

.container {
  position: relative;
  text-align: center;
  border: 1px solid;
  background: #f2f2f5;
}

img {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  max-height: 100%;
  max-width: 100%;
}
<!-- this one will not show -->
<div class="container" style="height:100%;">
  <img src="https://lorempixel.com/400/400/" />
</div>


<div style="height:200px">
  <!-- this one will  show -->
  <div class="container" style="height:100%;">
    <img src="https://lorempixel.com/400/400/" />
  </div>
</div>

如果你想使用div而不是图像,你可以考虑div中的图像,并使用fit-content值作为宽度/高度,诀窍是使图像不可见,并为文本添加另一个div内容(或其他任何内容)。

注意 fit-content 不是标准,因此并非所有浏览器都支持。因此,您可以将此解决方案视为伪解决方案而非通用解决方案

.container {
  position: relative;
  text-align: center;
  border: 1px solid;
  background: #f2f2f5;
}

.content {
  display: block;
  background: red;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  max-height: 100%;
  max-width: 100%;
  height: fit-content;
  width: fit-content;
}

.content img {
  visibility: hidden;
  z-index: -999;
  position: relative;
  max-height: 100%;
  max-width: 100%;
}

.text {
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  overflow: hidden;
}
<div class="container" style="width:400px;height:100px;">
  <div class="content">
    <img src="https://lorempixel.com/400/400/" />
    <div class="text"> lorem ipsum lorem ipsum </div>
  </div>
</div>
<div class="container" style="width:200px;height:400px;">
  <div class="content">
    <img src="https://lorempixel.com/400/400/" />
    <div class="text"> lorem ipsum lorem ipsum </div>
  </div>
</div>

<div class="container" style="width:400px;height:400px;">
  <div class="content">
    <img src="https://lorempixel.com/400/400/" />
    <div class="text"> lorem ipsum lorem ipsum </div>
  </div>
</div>
<div class="container" style="width:50px;height:600px;">
  <div class="content">
    <img src="https://lorempixel.com/400/400/" />
    <div class="text"> lorem ipsum lorem ipsum </div>
  </div>
</div>
<div class="container" style="width:600px;height:50px;">
  <div class="content">
    <img src="https://lorempixel.com/400/400/" />
    <div class="text"> lorem ipsum lorem ipsum </div>
  </div>
</div>

答案 3 :(得分:1)

你可以这样做:

&#13;
&#13;
html, body {width:100%;margin:0}

.container {
  position: relative;
  height: 300px; /* needs to be at least the height of the image */
  max-height: 100vh; /* enables vertical responsiveness */
  border: 1px solid Skyblue;
}

img {
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%); /* perfectly centered inside the container */
  display: block; /* removes bottom margin/white-space */
  max-width: 100%; /* horizontal responsiveness */
  max-height: 100vh; /* vertical responsiveness */
}
&#13;
<div class="container">
  <img src="http://lorempixel.com/300/300" alt="">
</div>
&#13;
&#13;
&#13;