flex列中行的高度不相等

问题描述 投票:1回答:1

我正在尝试进行如下图所示的布局,但是我不知道如何指定列以使其像它一部分的3/4,而另一部分是1/4,我是m尝试使用flexbox

我想要的布局看起来像:

enter image description here

我不知道该如何表达我的意思:D仍然是flexbox的新手。

但是在我尝试创建此东西的下面,但是我无法使第一列包含两个不相等的行。

.container {
  display: grid;
  width: 100%;
  height: 45vw;
  margin: auto;
  gap: 25px;
  border: 2px solid red;
  grid-template-columns: repeat(2, 1fr);
  grid-template-rows: repeat(2, 1fr);
  grid-template-areas:
    "cmd  grph grph grph  " 
    "write grph grph grph";
}

.box {
  display: flex;
  /*flex-direction: row;*/
  align-items: center;
  justify-content: center;
  border: 5px solid black;
}

.dot {
  height: 50px;
  width: 50px;
  background-color: blueviolet;
  border-radius: 50%;
}

.command {
  grid-area: cmd;
}

#grph {
  grid-area: grph;
}

#write {
  grid-area: write;
}
<div class="container">
  <div class="command box"></div>
  <div id="grph" class="box"></div>
  <div id="write" class="box"></div>
</div>
html css flexbox css-grid
1个回答
0
投票

这是您的代码:

.container {
   display: grid;
   grid-template-rows: repeat(2,fr);
}

如果要两个网格区域分别分割3/4和1/4,为什么要使用两行?请改用四行。

网格

.container {
  display: grid;
  height: 45vw;
  gap: 25px;
  border: 2px solid red;
  grid-template-columns: repeat(2, 1fr);
  grid-template-rows: repeat(4, 1fr);
  grid-template-areas:
    "cmd  grph grph grph  "
    "cmd  grph grph grph  "
    "cmd  grph grph grph  "    
    "write grph grph grph";
}

.command  { grid-area: cmd; }
#grph     { grid-area: grph;  }
#write    { grid-area: write; }

.box      { border: 5px solid black; }
<div class="container" id="cmd">
  <div class="command box"></div>
  <div id="grph" class="box"></div>
  <div id="write" class="box"></div>
</div>

Flex

这是flexbox解决方案:

.container {
  display: flex;
  flex-flow: column wrap;
  height: 45vw;
  border: 2px solid red;
}

.command {
  flex: 3;
  margin-bottom: 25px;
}

#grph {
  flex-basis: 100%;
  order: 1;
  margin-left: 25px;
}

#write {
  flex: 1;
}

.box {
  border: 5px solid black;
}
<div class="container" id="cmd">
  <div class="command box"></div>
  <div id="grph" class="box"></div>
  <div id="write" class="box"></div>
</div>
© www.soinside.com 2019 - 2024. All rights reserved.