首页 > 解决方案 > 2 个 div - 相同高度不同宽度,固定和动态

问题描述

好的,我编辑了我的问题和代码以轻松表达我的意思。我需要:

  1. “菜单” - 向左定位,最小高度 = 500 像素,宽度 = 250 像素 - 始终。
  2. “内容” - 位于“菜单”的右侧,动态宽度以占用所有剩余空间。
  3. “菜单”和“内容”的高度始终相同。“内容”内无论是 1 框还是 100 框。
  4. “盒子”应该从左到右排列,如果有更多,它们应该拉伸“内容”的高度,“菜单”应该遵循相同的高度。

<div class="header" style="height:150px; background-color:black;" >
</div>

<div class="navbar" style="height:40px; background-color:yellow;" >
</div>

<div class="menu" style="min-height:500px; width:250px; background-color:orange; float:left;" >
</div>

<div class="content" style="height:auto; background-color:blue; float: left; " >

    <?php for ($col = 0; $col < 50; $col++)
            {
    ?><div class="box" style="width:80px; height:80px; background-color:white; margin:10px;" ></div><?php
        }  
    ?>
</div>

标签: htmlcss

解决方案


* {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

div {
  border: 1px solid black
}

body {
  display: grid;
  grid-template-columns: 250px 1fr;
  grid-template-rows: 150px 40px minmax(500px , 1fr)
}

.header, .navbar {
  grid-column: 1 / -1
}

.content {
  display: grid;
  grid-gap: 20px;
  padding: 20px;
  grid-template-columns: repeat(auto-fill, 80px);
  align-content: start;
  justify-content: space-evenly;
}

.box {
  width: 80px;
  height: 80px;
}
<body>
  <div class='header'>
    Header
  </div>
  <div class='navbar'>
    Navbar
  </div>
  <div class='menu'>
    Menu
  </div>
  <div class='content'>
    <div class='box'>box</div>
    <div class='box'>box</div>
    <div class='box'>box</div>
    <div class='box'>box</div>
    <div class='box'>box</div>
    <div class='box'>box</div>
    <div class='box'>box</div>
    <div class='box'>box</div>
    <div class='box'>box</div>
    <div class='box'>box</div>
    <div class='box'>box</div>
    <div class='box'>box</div>
    <div class='box'>box</div>
    <div class='box'>box</div>
    <div class='box'>box</div>
    <div class='box'>box</div>
  </div>
</body>


推荐阅读