html - CSS 在任何分辨率下调整高度/宽度

标签 html css

我正在尝试构建可以在电视屏幕上运行的东西,分辨率会很大,但可以是任何分辨率。

我想出了以下几乎可以工作的 HTML/CSS 组合(但是,如果高度太小,表格会与页脚底部重叠,表格右侧的填充会与右侧重叠)

可以在这里找到 JS Fiddle:http://jsfiddle.net/hyLrj2t4/

HTML:

   <div class="flexbox-parent">
    <div class="flexbox-item header">
        Header
    </div>

    <div class="flexbox-item fill-area content flexbox-item-grow">
        <div class="fill-area-content flexbox-item-grow">
            <table width="100%" border="0" cellspacing="0" cellpadding="0">
      <tr>
       <td bgcolor="#FF0000">&nbsp;</td>
      </tr>
      <tr>
       <td bgcolor="#00FF00">&nbsp;</td>
      </tr>
      <tr>
       <td bgcolor="#0000FF">&nbsp;</td>
      </tr>
       <tr>
       <td bgcolor="#FF0000">&nbsp;</td>
      </tr>
       <tr>
       <td bgcolor="#00FF00">&nbsp;</td>
      </tr>
       <tr>
       <td bgcolor="#0000FF">&nbsp;</td>
      </tr>

    </table>
        </div>
    </div>

    <div class="flexbox-item footer">
        Footer
    </div>
</div>

CSS:

*, *:before, *:after
{
    -moz-box-sizing: border-box;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
}

html, body
{
    width: 100%;
    height: 100%;

    margin: 0;
    padding: 0;
}

body
{
    background: #444444;

    color: #cccccc;
    font-size: 14px;
    /* Helvetica/Arial-based sans serif stack */
    font-family: Frutiger, "Frutiger Linotype", Univers, Calibri, "Gill Sans", "Gill Sans MT", "Myriad Pro", Myriad, "DejaVu Sans Condensed", "Liberation Sans", "Nimbus Sans L", Tahoma, Geneva, "Helvetica Neue", Helvetica, Arial, sans-serif;

}

.flexbox-parent
{
    width: 100%;
    height: 100%;

    display: flex;
    flex-direction: column;

    justify-content: flex-start; /* align items in Main Axis */
    align-items: stretch; /* align items in Cross Axis */
    align-content: stretch; /* Extra space in Cross Axis */

    background: rgba(255, 255, 255, .1);
}

.flexbox-item
{
    padding: 0.5%;
}
.flexbox-item-grow
{
    flex: 1; /* same as flex: 1 1 auto; */
}

.flexbox-item.header
{
    background: rgba(255, 0, 0, .1);
}
.flexbox-item.footer
{
    background: rgba(0, 255, 0, .1);
}
.flexbox-item.content
{
    background: rgba(0, 0, 255, .1);
}

.fill-area
{
    display: flex;
    flex-direction: row;

    justify-content: flex-start; /* align items in Main Axis */
    align-items: stretch; /* align items in Cross Axis */
    align-content: stretch; /* Extra space in Cross Axis */

}
.fill-area-content
{
    background: rgba(0, 0, 0, .3);
    border: 1px solid #000000;

    /* Needed for when the area gets squished too far and there is content that can't be displayed */
    overflow: auto; 
}

table{
    height:88%;
    position:absolute;
    }

违规元素可以在黄色方 block 中看到:

enter image description here

最佳答案

看起来整个布局可以在没有 flex 的情况下完成,如果我正确的话,请参见如下简化的演示。

http://jsfiddle.net/1yp2jh2t/

html, body {
    margin: 0;
    height: 100%;
}
.container {
    display: table;
    width: 100%;
    height: 100%;
    background: #333;
    color: white;
}
.container > div {
    display: table-row;
}
.container > div > div {
    display: table-cell;
}
.container > div:nth-child(2) > div {
    height: 100%;
}
.container table {
    border-collapse: collapse;
    width: 100%;
    height: 100%;
}
<div class="container">
    <div><div>Header</div></div>
    <div>
        <div>
            <table>
                <tr><td bgcolor="#FF0000"></td></tr>
                <tr><td bgcolor="#00FF00"></td></tr>
                <tr><td bgcolor="#0000FF"></td></tr>
                <tr><td bgcolor="#FF0000"></td></tr>
                <tr><td bgcolor="#00FF00"></td></tr>
                <tr><td bgcolor="#0000FF"></td></tr>
            </table>
        </div>
    </div>
    <div><div>Footer</div></div>
</div>

关于html - CSS 在任何分辨率下调整高度/宽度,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30155392/

相关文章:

javascript - Skrollr 在 IOS 中不起作用,尽管我已经用 Skrollr Body 包裹了 body

html - 如何使用 css 添加 border-bottom-image

html - 如何创建要在网页中使用的 Logo 和图标

javascript - 对 'slideshow' 元素使用 CSS Sprite ?

html - Bootstrap 3 模板,所有内容都在一页上

c# - 从代码隐藏的 ASP.net 中的 <li> 标记中删除 CSS 类

javascript - 将 SELECT-OPTIONS 文本右对齐

javascript - 查找最长的元音子串

jquery - 如何减少 Fabric js 中文本对象的选择区域填充

javascript - 新的时间戳都是同一个日期