网格布局2列,垂直大小彼此独立

时间:2019-03-14 06:26:41

标签: html css css-grid

我创建了这个jsFiddle来显示问题。

下面的代码:

HTML:

<div id="container">
  <div id="left-col">
    LEFT
  </div>
  <div id="right-col1">
    RIGHT1
  </div>
  <div id="right-col2">
    RIGHT2
  </div>
  <div id="right-col3">
    RIGHT3
  </div>
</div>

CSS:

#container {
  display: grid;
  grid-template-columns: 15% 1fr;
  grid-template-areas:
  "left_area right_area1"
  "left_area right_area2"
  "left_area right_area3";
}

#left-col {
  grid-area: left_area;
}

#right-col1 {
  grid-area: right_area1;
}

#right-col2 {
  grid-area: right_area2;
}

#right-col3 {
  grid-area: right_area3;
}

当我在左列中有很大的垂直内容时,它会自动拉伸右边的内容,而在右列中的内容不会按照我的意愿显示。

我的目标是,如果无法取消链接,则右列将成为两列垂直大小的驱动力。

有没有办法做到这一点?

  • 使网格的垂直大小独立(似乎不太可能,或者不再是网格)?
  • 授权左列的溢出,以便右列的大小优先?

当然还有其他帮助。

1 个答案:

答案 0 :(得分:0)

这是因为您的容器div根据内部较大的div而增长。

如果要使右列独立于左列,则必须创建2个容器div:

<div id="container-left">
 <!-- Your left content -->
</div>
<div id="container-right">
 <!-- Your right content -->
</div>