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

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

新規登録して質問してみよう
ただいま回答率
85.47%
HTML

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

CSS

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

Q&A

解決済

2回答

2474閲覧

html/css 上部のメニューバーを浮いた形でなくこのteratailのメニューバーみたいにしたい

kay_ventris4

総合スコア269

HTML

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

CSS

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

0グッド

0クリップ

投稿2020/10/13 14:30

編集2020/10/13 14:41

###やってみたいこと

イメージ説明
HTML/CSS初心者です。ウェブページのサンプルを作っているのですが、一番上に表示するメニューバー(aquamarine)が、上の写真の様になってしまうのですが、そうではなくてページ上部が完全にaquamarineになる様に、別の言い方だと神社の鳥居みたいに(例え方が下手くそすぎて申し訳ありません)、「円」から短い縦棒取り除いたみたい(再度申し訳ありません)(伝わったでしょうか…?)にしたいです。

###該当コード

HTML

1<body> 2 <div> 3 <ul id='nav'> 4 <li><a href='***_main.html'>ホーム</a></li> 5 <li><a href='***'>***</a></li> 6 <li><a href='***'>More</a></li> 7 </ul> 8 </div> 9</body>

CSS

1 <style> 2 #nav { 3 list-style: none; 4 position: fixed; 5 overflow: hidden; 6 } 7 #nav li { 8 width: 250px; 9 background-color: aquamarine; 10 float: left; 11 text-align: center; 12 height: 60px; 13 padding: 6px; 14 padding-top: 50px; 15 } 16 #nav li a { 17 text-decoration: none; 18 color: black; 19 border-bottom: solid 1px black; 20 } 21 </style>

###やってみたこと
nav liのheightを色々調整してみたのですが、下に伸びるだけで上に伸びてくれません。調べようともしたのですが上の通り語彙が足りずうまく必要な情報に辿り着けませんでした。素人質問で恐縮ですが、お力添え頂ける箇所がございましたら、宜しくお願い申し上げます。

気になる質問をクリップする

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

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

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答2

0

ベストアンサー

HTML5で追加されたheader、main、footer 等のタグを使うようにしましょう。

header,footer,main,nav,article,aside,sectionの効果的な使い方

html

1<header> 2 <ul id='nav'> 3 <li><a href='***_main.html'>ホーム</a></li> 4 <li><a href='***'>***</a></li> 5 <li><a href='***'>More</a></li> 6 </ul> 7</header> 8<main> 9 10</main> 11<footer> 12 13</footer>

ブラウザのデフォルトの余白等をリセットしましょう。
(reset.css を使う方法もあります。調べてみてください。)

headerを上部に固定して画面全体に広げたいのなら、headerにその設定をしましょう。
width: 100%; position: fixed; など。

横並びさせるのに float: left;を使うのはいろいろ弊害があるのでやめましょう。
今は Flexboxを使うのが主流です。

もう迷わない!CSS Flexboxの使い方を徹底解説 | Web Design Trends

上記の方針で設計したCSSの一例

css

1* { /* とりあえず余白リセット */ 2 margin:0; 3 padding:0; 4} 5header { 6 width: 100%; 7 height: 120px; 8 background-color: aquamarine; 9 position: fixed; 10} 11#nav { 12 width: 1000px; 13 max-width: 100%; 14 margin: 0 auto; 15 height: 120px; 16 list-style: none; 17 overflow: hidden; 18 display: flex; 19 justify-content: space-between; 20 align-items: center; 21} 22#nav li { 23 width: 250px; 24 text-align: center; 25 padding: 6px; 26} 27#nav li a { 28 text-decoration: none; 29 color: black; 30 border-bottom: solid 1px black; 31}

投稿2020/10/13 17:35

hatena19

総合スコア33782

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

kay_ventris4

2020/10/14 01:43

ありがとうございます。余りの初心者にheaderを使うところからというあたりでしたが、包括的に色々な知識が見えてきました。reset.cssに関しては、もう少しゆっくり調べてみます。
guest

0

回答初心者です。
記載いただいた質問内容だけでは、的確な回答ができません。。。

cssの始めに*{margin:0;}を追記してみてください。

chromeの**「デベロッパーツール」**はご存じですか。
各箇所のcssの状態を確認できます。
各ブラウザごとにデフォルトで設定されているcssが影響してると判断しました。
(別件ですが、関連ワードとして、reset.cssというのがあります。)

投稿2020/10/13 15:39

編集2020/10/13 16:03
chemicalist11

総合スコア44

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

m.ts10806

2020/10/13 20:06 編集

デベロッパツール使うのなら、「teratailのような」と要件にありますし、 teratailのメニューバーがどうなっているか解析するのも手ですね。 https://ascii.jp/elem/000/000/999/999122/
kay_ventris4

2020/10/14 01:44

ありがとうございます。言葉足らずで申し訳ありませんでした。もう一人の回答を頂いた方のプログラムとも合わせてみて、* {margin: 0;}で上の余白を消すことが出来ました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.47%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問