鉴于此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;
}
从视觉上看,它们具有相同的效果。
答案 0 :(得分:1)
通常,width:auto
会使元素占用所有可用空间。在基本层面上,如果某个空间被占用,它将占据其余空间。另一方面,width: 100%
意味着该元素将占据其整个父元素。
flex-grow: 2
,则它将占用两倍于其他元素的空间