我正在尝试设计以下布局:
如何设置每个图块的高度,使其在大屏幕显示器中正确缩放。我尝试在px中设置最小高度,以%为单位设置高度。但在大型显示器中,底部似乎有白色空间。
如何确保大屏幕底部没有空白区域,同时在普通笔记本电脑显示屏(mdpi)中完美贴合,并且在移动设备中也可以堆叠在另一个下方(即响应速度快)。我应该使用哪些单位。
答案 0 :(得分:3)
所以这可以通过flexbox
来实现 - 你可以看到它显然是响应性的。
我在这里创建了一个视口高flexbox
。您可以根据需要调整height
wrapper
来获取它。有关正在进行相同操作的另一个示例,请参阅this answer too。
为了展示动态内容在此布局中的行为方式,请在此处使用此css添加一些文本内容:
.content{
display: flex;
align-items: center;
justify-content: center;
overflow-y: auto;
}
检查一下,让我知道您对此的反馈。谢谢!
body {
margin: 0;
}
* {
box-sizing: border-box;
}
.wrapper {
display: flex;
height: 100vh;
}
.wrapper > div:last-child {
width: 50%;
border: 1px solid;
}
.wrapper > div:first-child {
display: flex;
flex-direction: column;
width: 50%;
height: 100%;
}
.wrapper > div:first-child > div:last-child {
width: 100%;
height: 50%;
border: 1px solid;
}
.wrapper > div:first-child > div:first-child {
height: 50%;
display: flex;
}
.wrapper > div:first-child > div:first-child > div {
width: 50%;
height: 100%;
display: flex;
flex-direction: column;
}
.wrapper > div:first-child > div:first-child > div:last-child {
border: 1px solid;
}
.wrapper > div:first-child > div:first-child > div:first-child > div {
height: 50%;
border: 1px solid;
}
.content {
display: flex;
align-items: center;
justify-content: center;
overflow-y: auto;
}
@media only screen and (max-width: 650px) {
.wrapper {
display: flex;
flex-direction: column;
height: auto;
}
.wrapper > div:first-child,
.wrapper > div:last-child {
width: 100%;
}
.wrapper > div:first-child > div:first-child {
width: 100%;
flex-direction: column;
}
.wrapper > div:first-child > div:first-child > div {
width: 100%;
}
}

<div class="wrapper">
<div>
<div>
<div>
<div class="content">
Lorem ipsum dolor sit amet, consectetuer adipiscing elit. Aenean commodo ligula eget dolor. Aenean massa. Cum sociis natoque penatibus et magnis dis parturient montes, nascetur ridiculus mus. Donec quam felis, ultricies nec, pellentesque eu, pretium quis,
sem. Nulla consequat massa quis enim. Donec pede justo, fringilla vel, aliquet nec, vulputate eget, arcu.
</div>
<div class="content">
Lorem ipsum dolor sit amet, consectetuer adipiscing elit. Aenean commodo ligula eget dolor. Aenean massa. Cum sociis natoque penatibus et magnis dis parturient montes, nascetur ridiculus mus. Donec quam felis, ultricies nec, pellentesque eu, pretium quis,
sem. Nulla consequat massa quis enim. Donec pede justo, fringilla vel, aliquet nec, vulputate eget, arcu.
</div>
</div>
<div class="content">
Lorem ipsum dolor sit amet, consectetuer adipiscing elit. Aenean commodo ligula eget dolor. Aenean massa. Cum sociis natoque penatibus et magnis dis parturient montes, nascetur ridiculus mus. Donec quam felis, ultricies nec, pellentesque eu, pretium quis,
sem. Nulla consequat massa quis enim. Donec pede justo, fringilla vel, aliquet nec, vulputate eget, arcu.
</div>
</div>
<div class="content">
Lorem ipsum dolor sit amet, consectetuer adipiscing elit. Aenean commodo ligula eget dolor. Aenean massa. Cum sociis natoque penatibus et magnis dis parturient montes, nascetur ridiculus mus. Donec quam felis, ultricies nec, pellentesque eu, pretium quis,
sem. Nulla consequat massa quis enim. Donec pede justo, fringilla vel, aliquet nec, vulputate eget, arcu.
</div>
</div>
<div class="content">
Lorem ipsum dolor sit amet, consectetuer adipiscing elit. Aenean commodo ligula eget dolor. Aenean massa. Cum sociis natoque penatibus et magnis dis parturient montes, nascetur ridiculus mus. Donec quam felis, ultricies nec, pellentesque eu, pretium quis,
sem. Nulla consequat massa quis enim. Donec pede justo, fringilla vel, aliquet nec, vulputate eget, arcu.
</div>
</div>
&#13;
答案 1 :(得分:0)
CSS3 flexbox将允许您轻松完成此操作。
以下是一些可以帮助您入门的链接:
https://envato.com/blog/css3-flexbox/
Understanding CSS3 Flexbox
另外还有很多关于这个主题的网页。谷歌是你的朋友