2格-同一高度不同宽度,固定和动态

时间:2018-08-10 05:29:38

标签: html css

好的,我编辑了问题和代码,以轻松显示我的意思。我需要具备:

  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>

2 个答案:

答案 0 :(得分:2)

* {
  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>

答案 1 :(得分:0)

使用Flexbox可以更轻松地实现您的目标,如下面的解决方案所示。

.header {
  height: 150px; 
  background-color: black;
}

.navbar {
  height: 40px; 
  background-color: yellow;
}

.container {
  min-height: 500px;
  display: flex;
  align-items: flex-start;
}

.menu {
  min-height: 500px;
  height: 100%;
  width: 250px; 
  background-color: orange; 
}

.content {
  min-height: 500px;
  background-color: blue; 
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
}

.box {
  width: 80px; 
  height: 80px; 
  background-color: white; 
  margin: 10px;
}
<div class="header">
</div>

<div class="navbar">
</div>

<div class="container">
  <div class="menu">
  </div>

  <div class="content">
    <div class="box"></div>
    <div class="box"></div>
    <div class="box"></div>
    <div class="box"></div>
    <div class="box"></div>
    <div class="box"></div>
    <div class="box"></div>
    <div class="box"></div>
    <div class="box"></div>
    <div class="box"></div>
    <div class="box"></div>
    <div class="box"></div>
  </div>
</div>