我如何给div一个响应高度

时间:2013-02-05 18:53:34

标签: html css responsive-design

我说要学习响应式设计,但到目前为止我还有一件事似乎无法弄明白......

以下是一个有效的例子:http://ericbrockmanwebsites.com/dev1/

我想把div元素(contactBg)里面的文字放到左边的图像底部。显然我可以通过在px中定义高度来做到这一点,但是当窗口的其余部分调整大小而不是流动时,该高度会保持不变。

如果有任何好的文章,你可能知道这解释了如何做到这一点,这将非常有帮助,谢谢!

这是标记:

<div class="row-fluid">
        <div class="span10 offset1">
            <div class="container-fluid">
                <div class="row-fluid">
                    <div class="span5">
                        <img src="images/logo.jpg" alt="logo" />
                        <img src="images/store.jpg" alt="store" />
                    </div><!-- /span5 -->
                    <div class="span7">
                        <img src="images/portal.jpg" alt="portal">
                        <div class="contactBg">
                            Administration: Emma Jane Julien<br />
                            <a href="mailto:ej@emmajulien.com">ej@emmajulien.com</a>
                        </div><!-- /contactBg -->
                    </div><!-- /span7 -->
                </div><!-- /row-fluid -->
            </div><!-- /container-fluid -->
        </div><!-- /span10 offset1 -->
    </div> <!-- /row-fluid -->

这是css:

   body {
        background: url(../images/3D2A1698A177AF9B71_218.png) repeat;
    }

    img {
        max-width:100%;
        padding-bottom:1%;
    }

     .container-fluid {
        background:#fff;
        padding: 1%;
    }

      .row-fluid {
        width: 100%;
        *zoom: 1;
 }
      .row-fluid [class*="span"] {
        display: block;
        float: left;
        width: 100%;
        min-height: 30px;
        margin-left: 1%;
        *margin-left: 2.709239449864817%;
        -webkit-box-sizing: border-box;
           -moz-box-sizing: border-box;
                box-sizing: border-box;
}

      .row-fluid .span10 {
        width: 82.87292817679558%;
        *width: 82.81973668743387%;
      }

      .row-fluid .span7 {
        width: 58.06353591160195%;
        *width: 57.12912895262725%;
      }

      .row-fluid .span5 {
        width: 40.93646408839753%;
        *width: 40.00205712942283%;
      }
      .row-fluid .span4 {
        width: 31.491712707182323%;
        *width: 31.43852121782062%;
      }

    .contactBg {
        background: #282624;
        padding: 3%;
        max-width:100%;
        height:auto;
    }

3 个答案:

答案 0 :(得分:13)

我知道派对有点晚了但你可以使用视口单元

来自caniuse.com:

视口单位:vw,vh,vmin,vmax - CR 长度单位表示视口宽度(vw),高度(vh)的视口大小的1%,两者中的较小者(vmin)或两者中的较大者(vmax)。

支持:http://caniuse.com/#feat=viewport-units

FragmentManager fm = getSupportFragmentManager();
fm.bginTransaction()
  .remove(oldFragment)
  .add(newFragment)
  .commit();
div {
/* 25% of viewport */
  height: 25vh;
  width: 15rem;
  background-color: #222;
  color: #eee;
  font-family: monospace;
  padding: 2rem;
}

答案 1 :(得分:6)

对于要响应的div的高度,它必须位于具有已定义高度的父元素内,以从中获得它的相对高度。

如果您在右侧设置了包含图片和文本框的容器的高度,则可以随后将其两个孩子的高度设置为75%和25%。

然而,当网站布局变得更窄并且事情变得不稳定时,这将变得有点棘手。尝试将.contentBg上的填充设置为5.5%。

我的建议是使用媒体查询来调整不同屏幕尺寸的填充,然后在适当的时候将所有内容放到一个列中。

答案 2 :(得分:0)

我不认为这是最好的解决方案,但它似乎确实有效。我不打算使用背景颜色,而是将嵌入背景图像,相对定位,然后将文本包装在子元素中并将其置于绝对位置 - 位于中心。