質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

ただいまの
回答率

90.84%

  • HTML

    8072questions

    HTMLとは、ウェブ上の文書を記述・作成するためのマークアップ言語のことです。文章の中に記述することで、文書の論理構造などを設定することができます。ハイパーリンクを設定できるハイパーテキストであり、画像・リスト・表などのデータファイルをリンクする情報に結びつけて情報を整理します。現在あるネットワーク上のほとんどのウェブページはHTMLで作成されています。

  • CSS

    5156questions

    CSSはXMLやHTMLで表現した色・レイアウト・フォントなどの要素を指示する仕様の1つです。

  • HTML5

    3619questions

    HTML5 (Hyper Text Markup Language、バージョン 5)は、マークアップ言語であるHTMLの第5版です。

  • CSS3

    1863questions

    CSS(Cascading Style Sheet)の第3版です。CSS3と略されることが多いです。色やデザインを柔軟に変更することが可能になります。

html5 css3 画面レイアウトにつきまして

解決済

回答 1

投稿 編集

  • 評価
  • クリップ 0
  • VIEW 108

mgm

score 5

【やりたいこと】
スマホ用サイトです。
画面を縦四つに分けて(上から、タイトル→メニュー→画像→フッター)、
画面の縦の割合を%で指定し、フッターは最下部に固定したいです。
(メニューの高さ20%、フッター10%、タイトル・画像は出来ればauto指定)

【問題点】
1、上の方に重なってしまい画像が見えなくなっている(タイトルは通常に表示中)

2、メニューの高さが低い(5%くらいに見える)

下記がコードになります。
どうぞよろしくお願い致します。

【html】
<meta name="viewport" content="width=device-width,height=device-height,initial-scale=1.0,user-scalable=no">

<body>
<div id="container">
<div id="contents">
<div id="menu">
</div>
</div> <!--contents-->
<div id="footer">
</div>
</div> <!--container-->
<body>


【css】
body {
position:relative;
height: 100%;
} 

#container {
height: auto;
width: 100%;
}

#contents{
height: 100%;
width: 100%;
bottom: 0;
}

#menu{
position: absolute;
height: 20%;
width: 100%;
}

#footer{
position: fixed;
height: 10%;
bottom: 0;
width: 100%;
}
  • 気になる質問をクリップする

    クリップした質問は、後からいつでもマイページで確認できます。

    またクリップした質問に回答があった際、通知やメールを受け取ることができます。

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

質問への追記・修正、ベストアンサー選択の依頼

  • kei344

    2018/06/02 20:40

    質問文のコードはそれぞれコードブロックで囲んでいただけませんか? ```(バッククオート3つ)で囲み、前後に改行をいれるか、コードを選択して「<code>」ボタンを押すとコードブロックになります。

    キャンセル

  • mgm

    2018/06/02 21:45

    ありがとうございます。編集しました。

    キャンセル

  • yoshinavi

    2018/06/03 15:03

    表示させたい要素とHTMLのタグが一致していないと思います。どこが「タイトル」なのか?どこに「画像」が入るのか?です。HTMLタグの設定から見直されると良いかと思います。

    キャンセル

回答 1

checkベストアンサー

0

とりあえず下記CSSを追加すれば「メニューの高さ」は問題なくなると思います。

html {
    height: 100%;
}

body {
    margin: 0;
    padding: 0;
}

動くサンプル:https://jsfiddle.net/x8rrnudw/


画面に対する比率を固定したいなら vh vw を使うほうが良いです。

【CSS には vw, vh, vmin, vmax という単位がある | Developers.IO】
https://dev.classmethod.jp/ria/html5/css-length-viewport/

【レスポンシブに便利なCSSのvh/vw/vmin/vmaxの基本と使い方とは - WPJ】
https://www.webprofessional.jp/css-viewport-units-quick-start/

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2018/06/02 23:57

    ありがとうございます。メニューが希望通り表示されており助かりました。
    残りの問題はメニューの下に画像が潜り込んでいるのか、
    現状見えないという点のみとなりました・・。

    キャンセル

  • 2018/06/03 00:09

    提示されたHTMLに画像が記載されていないため、状況が正確にはわかりませんが、#menuをposition: absolute;させなければ潜り込むこともありませんよ。

    キャンセル

15分調べてもわからないことは、teratailで質問しよう!

  • ただいまの回答率 90.84%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

関連した質問

  • 解決済

    CSSでnavを左によせたい

    navを左に寄せたい navを左に寄せたいのですがしたに表示されます。左に表示する方法を教えてください html{ margin:0; padding:0;height:100

  • 解決済

    ページ上部にスクロール設定について

    ページの右下に、クリックするとページ上部に行く設定をしたのですが、スクロール位置を1000以下にすると非表示に設定をhead内に記述したのですが実行できません。 ご教授頂けますと嬉

  • 受付中

    レスポンシブルデザインについて

    ページ上部のメニューをクリックしたらスマホのサイトのようなメニューバーを表示させたいのですがどうすればよろしいでしょうか。 ちなみにこちらのサイトを参考にしました https://

  • 解決済

    レスポンシブデザインについて

    この画像の上部の油そば池袋とありますが幅を小さくしていくと 赤枠の箇所に油そば池袋と入れたいのですがどうすればよろしいでしょうか <!DOCTYPE html> <html

  • 受付中

    レスポンシブデザインのメニューの幅のサイズが変更できない

    こちらのサイトを参考にして、ウィンドウ幅が小さくなったときスマホサイト用にメニューが出る設定をしたのですが幅が表示されるときのウィンドウ枠の数値をjquery.meanmenu.j

  • 解決済

    menuバーの中央配置について

    pc-menu内の<h1 class="aburasoba">油そば池袋</h1>を削除した際にliでかこった<li>menu</li>を中央配置にしたいのですがfloat: ce

  • 解決済

    footerの下に余白があく

    前提・実現したいこと footerの下に余白があく。余白を0pxもあかないようにしたい。 発生している問題・エラーメッセージ 特にエラーは発生していない。 該当のソースコー

  • 解決済

    divで囲んだ部分が縦に並ばない

    前提・実現したいこと divのitemsクラスで囲んだ部分が縦に並ばない。 col-xs-8とcol-xs-4を使い画面を8:4に分けてその4の部分に画像を縦に並べたい。 発生

同じタグがついた質問を見る

  • HTML

    8072questions

    HTMLとは、ウェブ上の文書を記述・作成するためのマークアップ言語のことです。文章の中に記述することで、文書の論理構造などを設定することができます。ハイパーリンクを設定できるハイパーテキストであり、画像・リスト・表などのデータファイルをリンクする情報に結びつけて情報を整理します。現在あるネットワーク上のほとんどのウェブページはHTMLで作成されています。

  • CSS

    5156questions

    CSSはXMLやHTMLで表現した色・レイアウト・フォントなどの要素を指示する仕様の1つです。

  • HTML5

    3619questions

    HTML5 (Hyper Text Markup Language、バージョン 5)は、マークアップ言語であるHTMLの第5版です。

  • CSS3

    1863questions

    CSS(Cascading Style Sheet)の第3版です。CSS3と略されることが多いです。色やデザインを柔軟に変更することが可能になります。