本文介绍了CSS 100%高度布局的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我知道这是一个常见的问题,我找了一些解决方案,但找不到我正在寻找的是什么。



我想转换。


I know this is a sort of a common problem, and I looked up some solutions, but couldn't find exactly what I was looking for.

I would like to convert this to a tableless layout.

Note: header and footer have to be set to a fixed height in pixels (50px is ok).

The main problem I'm having is that I cannot get that "big box" in the middle to behave like it does when it's done with tables. There are solutions which work OK for a variable length content (text, images), but I would like this box look and behave like a box - with borders, rounded corners and all.

解决方案

You can do it with table style CSS properties, but still retain table less markup (which is still a win).

Example

HTML

<div id="container">
    <div id="header"><div>header</div></div>
    <div id="content"><div>content</div></div>
    <div id="footer"><div>footer</div></div>
</div>

CSS

html,
body {
    height: 100%;
    padding: 0;
    margin: 0;
}

#container {
    display: table;
    width: 100%;
    height: 100%;
    border: 1px solid red;
    text-align: center;
}

#container > div {
    display: table-row;
    width: 100%;
}

#container > div > div {
    display: table-cell;
    width: 100%;
    border-radius:10px;

}

#header > div {
    height:50px;
    border:solid 2px #aaa;
}

#content > div {
    height: 100%;
    background:#f0f4f0;
    border:solid 2px #5a5;
}

#footer > div {
    height:50px;
    border:solid 2px #a55;
}

jsFiddle.

这篇关于CSS 100%高度布局的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持!

08-22 16:25