flex-grow = 1,width:auto和just width:100%之间的差异

时间:2016-10-19 10:46:56

标签: html css3 flexbox off-canvas-menu

鉴于此HTML:

<nav id="drawer" class="dark_blue">
  <h2>Off Canvas</h2>
  <p>Click outside the drawer to close</p>
</nav>

<main class="light_blue">
  <a id="menu">
    <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24">
      <path d="M2 6h20v3H2zm0 5h20v3H2zm0 5h20v3H2z"/>
    </svg>
  </a>
  <p>Click on the menu icon to open the drawer</p>
</main>

这些CSS属性(它们真的在媒体查询中)

body {
     display: -webkit-flex;
     display: flex;
 }

 main {
     width: auto;
     /* Flex-grow streches the main content to fill all available space.*/
     flex-grow: 1;
 }

我不能只使用

main {
   width: 100%;
}

而不是

main {
    width: auto;
    flex-grow: 1;
}

从视觉上看,它们具有相同的效果。

此处a working JSFiddle

1 个答案:

答案 0 :(得分:1)

通常,width:auto会使元素占用所有可用空间。在基本层面上,如果某个空间被占用,它将占据其余空间。另一方面,width: 100%意味着该元素将占据其整个父元素。

然而,Flex表示,元素占据了多少空间。如果父级中有两个子元素,并且您给其中一个flex-grow: 2,则它将占用两倍于其他元素的空间