0

私は自分のウェブスキルを向上させるために小さなブラウザゲームを書いていますが、レイアウトの問題で立ち往生しています。私のゲームページは、ヘッダー、コンテンツ、および背景画像を間に挟んだ2つのスペーサーを含むフッターで構成されています。content-divは、ビューのスペース全体が使用されるように、垂直方向に引き伸ばす必要があります。コンテンツがブラウザよりも高い場合は、スクロールバーを使用してさらに拡大する必要があります。背景にグラデーションの塗りつぶしを使用しているので、高さが正しいことが重要です。これは、ある時点で繰り返されるべきではありません。これは、サイズが大きいコンテンツの場合はheight:autoで、サイズが小さいコンテンツの場合はmin-height:100%で実現できると思いました。しかし、これは機能しません。いくつかのフォーラム投稿を読みましたが、何も機能していません。私を手伝ってくれますか?推論の私の誤りはどこにありますか?

HTML :( brはページのサイズを大きくするために使用されます)

<html>
<head>
  <link rel="stylesheet" type="text/css" href="mycss.css">
</head>
<body>
  <div class="center">
    <div class="header">
      Header
    </div>
    <div class="spacer"></div>
    <div class="main">
      Content
      <!--<br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/>
            <br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/>-->
    </div>
    <div class="spacer"></div>
    <div class="footer">
      Footer
    </div>
  </div>
</body>
</html>

CSS:

html,body {
    margin:0px;
    padding:0px;
    height: auto;
    min-height: 100%;
}

body {

    background: rgb(122,188,255); /* Old browsers */
    background: -moz-linear-gradient(top,  rgba(122,188,255,1) 0%, rgba(96,171,248,1) 44%, rgba(64,150,238,1) 100%); /* FF3.6+ */
    background: -webkit-gradient(linear, left top, left bottom, color-stop(0%,rgba(122,188,255,1)), color-stop(44%,rgba(96,171,248,1)), color-stop(100%,rgba(64,150,238,1))); /* Chrome,Safari4+ */
    background: -webkit-linear-gradient(top,  rgba(122,188,255,1) 0%,rgba(96,171,248,1) 44%,rgba(64,150,238,1) 100%); /* Chrome10+,Safari5.1+ */
    background: -o-linear-gradient(top,  rgba(122,188,255,1) 0%,rgba(96,171,248,1) 44%,rgba(64,150,238,1) 100%); /* Opera 11.10+ */
    background: -ms-linear-gradient(top,  rgba(122,188,255,1) 0%,rgba(96,171,248,1) 44%,rgba(64,150,238,1) 100%); /* IE10+ */
    background: linear-gradient(top,  rgba(122,188,255,1) 0%,rgba(96,171,248,1) 44%,rgba(64,150,238,1) 100%); /* W3C */
    filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#7abcff', endColorstr='#4096ee',GradientType=0 ); /* IE6-9 */

}

.center {
    height: auto;
    min-height: 100%;

    width:1024px;
    margin-left:auto;
    margin-right:auto;
    text-align:left;

    box-shadow: 0px 0px 20px 0px #000;

    background: rgb(181,189,200); /* Old browsers */
    background: -moz-linear-gradient(top,  rgba(181,189,200,1) 0%, rgba(130,140,149,1) 36%, rgba(117,117,117,1) 100%); /* FF3.6+ */
    background: -webkit-gradient(linear, left top, left bottom, color-stop(0%,rgba(181,189,200,1)), color-stop(36%,rgba(130,140,149,1)), color-stop(100%,rgba(117,117,117,1))); /* Chrome,Safari4+ */
    background: -webkit-linear-gradient(top,  rgba(181,189,200,1) 0%,rgba(130,140,149,1) 36%,rgba(117,117,117,1) 100%); /* Chrome10+,Safari5.1+ */
    background: -o-linear-gradient(top,  rgba(181,189,200,1) 0%,rgba(130,140,149,1) 36%,rgba(117,117,117,1) 100%); /* Opera 11.10+ */
    background: -ms-linear-gradient(top,  rgba(181,189,200,1) 0%,rgba(130,140,149,1) 36%,rgba(117,117,117,1) 100%); /* IE10+ */
    background: linear-gradient(top,  rgba(181,189,200,1) 0%,rgba(130,140,149,1) 36%,rgba(117,117,117,1) 100%); /* W3C */
    filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#b5bdc8', endColorstr='#757575',GradientType=0 ); /* IE6-9 */

}

.spacer{
    min-height:16px;
    background-image: url(Absperrband.png);
    background-repeat: repeat;
    -webkit-box-shadow: 0px 0px 5px 0px #000;
            box-shadow: 0px 0px 5px 0px #000;
}

.header {
    padding : 8px;
    height:70px;
}

.main{
    min-height: 100%;
    padding : 12px;
}

.footer{
    padding : 12px;
}
4

4 に答える 4

1

「スティッキーフッター」効果を探しているようですね。

http://www.cssstickyfooter.com/

于 2012-10-30T12:21:34.497 に答える
0

html、body である必要がheight:100%あり、メインの div (.center) にはmin-height:100%; height:auto

デモ

于 2012-10-30T11:28:37.980 に答える
0

に追加display:inline-block;body.center 結果を確認します

于 2012-10-30T12:07:16.733 に答える
0

とに追加display:inline-block;text-align:center;_bodydisplay:inline-block;text-align:left;.center

それが私の答えを修正できることを願っています

于 2012-10-31T10:44:04.047 に答える