如何使用 flexbox 创建侧边栏和内容区域? [英] How to create a sidebar and content area using flexbox?
问题描述
我想使用 flexbox 来创建侧边栏和主要内容区域.侧边栏的高度应该至少是窗口的高度.但是,如果内容高度大于窗口,则侧边栏的高度应该增长以匹配内容的高度.这个想法是,当我们滚动查看所有内容时,侧边栏应该看起来好像它延伸到与内容相同的高度.
这是我的尝试:http://codepen.io/nareshbhatia/pen/QbZqyd.使窗口宽度非常小.不幸的是,侧边栏仅延伸到窗口高度.同样,当我向下滚动时,内容区域会失去背景颜色.
完整代码如下:
HTML
<div class="sidenav"><ul><li>项目 1</li><li>项目 2</li><div class="内容">lorem ipsum lorem ...
CSS
html, body {边距:0;高度:100%;}.flex 容器 {显示:-webkit-flex;显示:弹性;背景颜色:红色;高度:100%;}.sidenav {背景颜色:浅灰色;-webkit-flex: 1;弹性:1;}.内容 {背景颜色:浅蓝色;填充:10px;-webkit-flex: 5;弹性:5;}
你只需要使用 min-height
而不是 height
html, body {边距:0;高度:100%;}身体 {高度:100%;}.flex 容器 {显示:-webkit-flex;显示:弹性;背景颜色:红色;最小高度:100%;}
html,身体 {边距:0;高度:100%;}身体 {高度:100%;}.flex 容器 {显示:-webkit-flex;显示:弹性;背景颜色:红色;最小高度:100%;}.sidenav {背景颜色:浅灰色;-webkit-flex: 1;弹性:1;}.内容 {背景颜色:浅蓝色;填充:10px;-webkit-flex: 5;弹性:5;高度:2000px;}
<div class="flex-container"><div class="sidenav"><ul><li>项目 1</li>
<div class="内容">lorem ipsum lorem ipsum lorem ipsum ipsum ipsum lorem ipsum lorem ipsum lorem ipsum lorem ipsum lorem ipsum lorem ipsum lorem ipsum lorem ipsum lorem ipsum lorem ipsum ipsum ipsum ipsum ipsumlorem ipsum lorem ipsum lorem ipsum ipsum ipsum ipsum lorem ipsum lorem ipsum lorem ipsumipsum lorem ipsum lorem ipsum lorem ipsum lorem ipsum loremlorem ipsum lorem ipsum lorem ipsum lorem ipsum lorem ipsum lorem ipsum lorem ipsum lorem ipsum lorem ipsum lorem ipsum lorem ipsum lorem ipsum lorem ipsum lorem ipsum lorem ipsum lorem ipsum lorem ipsum