首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >在CSS网格中使用minmax()函数

在CSS网格中使用minmax()函数
EN

Stack Overflow用户
提问于 2022-06-15 20:08:14
回答 1查看 257关注 0票数 1

我有一个2列x2行的网格。它们都设置为minmax()大小。我可以问为什么show类的元素不接受网格的全部大小,即使我将网格中的所有其他元素(hide类)设置为宽度0和高度0。minmax()不能正常工作吗?

代码语言:javascript
复制
* {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

 :root {
  --seemoresz: 100px;
}

#outer {
  display: grid;
  grid-template-columns: minmax(calc(700px - var(--seemoresz)), 700px) minmax(0px, var(--seemoresz));
  grid-template-rows: minmax(0px, var(--seemoresz)) minmax(calc(700px - var(--seemoresz)), 700px);
  width: 700px;
  height: 700px;
  overflow: hidden;
  background-color: aqua;
}

.hide {
  width: 0;
  height: 0;
}
代码语言:javascript
复制
<div id="outer">
  <div class="hide">
    hide this
  </div>
  <div class="hide">
    hide this
  </div>
  <div class="show">
    show this
  </div>
  <div class="hide">
    hide this
  </div>
</div>

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2022-06-16 02:43:30

minmax()函数运行良好。calc()函数也是如此。

问题是对设定的最小高度和宽度有误解。

即使将网格项设置为零宽度和高度:

代码语言:javascript
复制
.hide {
  width: 0;
  height: 0;
}

...the网格列有自己的宽度和高度:

代码语言:javascript
复制
#outer {
  display: grid;
  grid-template-columns: minmax(calc(700px - var(--seemoresz)), 700px) minmax(0px, var(--seemoresz));
  grid-template-rows: minmax(0px, var(--seemoresz)) minmax(calc(700px - var(--seemoresz)), 700px);
} 

列和行不会收缩到零,这会阻止.show在整个容器中展开。

考虑在auto中使用minmax()而不是minmax()。这将使列/行能够跟踪网格项的大小。

还考虑这些员额中的解决办法:

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/72637279

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档