An Expanding Middle In CSS
Solution 1:
I think this is what you want:
HTML:
<div id="header">Patrick</div>
<div id="content">..</div>
<div id="footer">Beardmore</div>
CSS:
html, body {
margin: 0;
padding: 0;
border: 0;
overflow: hidden
}
#header, #content, #footer {
position: absolute;
left: 0;
width: 100%
}
#header {
top: 0;
height: 100px;
background: #ccc
}
#content {
top: 100px;
bottom: 100px;
overflow-y: auto
}
#footer {
bottom: 0;
height: 100px;
background: #ccc
}
Solution 2:
It's called StickyFooter or the "footer push" method. It's all over the web, but this is the best option I've found:
Solution 3:
An old question, but flexbox has given us a super easy way to implement this pattern, a familiar variation on the 'Holy Grail' layout:
body {
/*set container to vertical (column) flex mode, ensure body is full height*/
display: flex;
min-height: 100vh;
flex-direction: column;
}
header, footer {
/*more or less equivalent to min-height:50px*/
flex-basis:50px
}
header {
background-color: #7AEE2D;
}
main {
background-color: #EBAE30;
/*tell main section to expand to fill available space, this is same as flex 1; or flex:1 1 auto;*/
flex-grow:1;
}
footer {
background-color: #34A4E7;
}
<header>header</header>
<main>main</main>
<footer>footer</footer>
A note about the syntax: I've used the "atomic" flexbox CSS properties here for simplicity, but in the wild you are more likely to run into the shorthand syntax using the flex
keyword by itself. The default values for the 3 properties you can set on flex items (children of a display:flex
container) are:
Initial value as each of the properties of the shorthand: flex-grow: 0 flex-shrink: 1 flex-basis: auto
Using flex
, there are multiple ways to compose these properties, specifying one, two, or three values, and those values can by keywords, unit lengths (2px
), or unitless grow/shrink ratios 2
. Many different "overloads" are available, depending on your arguments.
For example, flex-basis:50px
could've been flex:50px
, flex:0 1 50px
, and flex-grow:1
could have been flex 1;
or flex:1 1 auto;
. It's still not as bad as some other CSS shorthands I can think of (position
, I'm looking at you). The 'flex' shorthand syntax MDN page has more details.
Post a Comment for "An Expanding Middle In CSS"