1

鉴于此 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;
}

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

在这里,一个工作的 JSFiddle

4

1 回答 1

1

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

然而,Flex grow 表示元素占用了多少空间。如果父元素中有两个子元素,并且你给其中一个 aflex-grow: 2它将占用另一个空间的两倍

于 2016-10-19T11:02:38.447 回答