オーダーメイドコース
icon
icon

CSSでフローティングメニューを作成する方法【初心者向け】

初心者向けにCSSでフローティングメニューを作成する方法について解説しています。フローティングメニューとは画面の一番下に固定で表示されるメニューのことです。floatプロパティを使って浮かせてからpositionプロパティを使って固定します。

テックアカデミーマガジンは受講者数No.1のプログラミングスクール「テックアカデミー」が運営。初心者向けにプロが解説した記事を公開中。現役エンジニアの方はこちらをご覧ください。 ※ アンケートモニター提供元:GMOリサーチ株式会社 調査期間:2021年8月12日~8月16日  調査対象:2020年8月以降にプログラミングスクールを受講した18~80歳の男女1,000名  調査手法:インターネット調査

CSSでフローティングメニューを作成する方法について解説します。フローティングメニューは画面の一番下に固定で表示されるメニューのことです。

そもそもCSSについてよく分からないという方は、CSSの書き方について解説した記事を読むとさらに理解が深まります。

 

なお本記事は、TechAcademyのオンラインブートキャンプWebデザイン講座のCSSカリキュラムをもとに執筆しています。

 

田島悠介

今回は、CSSに関する内容だね!

大石ゆかり

どういう内容でしょうか?

田島悠介

CSSでフローティングメニューを作成する方法について詳しく説明していくね!

大石ゆかり

お願いします!

 

フローティングメニューとは

スマホ画面をスクロールさせても、いつも一番上に表示されているナビゲーションやボタンのことをフローティングメニューと言います。

 

フローティングメニューの書き方

要素をタグで囲み、ボックスはfloat属性を指定し、他のボックスから影響を受けない、フローティングボックスにさせます。

他の要素とfloat の指定が他の要素と干渉しないよう clearfixを設定します。

 

[PR] Webデザインで副業する方法とは

実際に書いてみよう

 

HTML

<table border="2" cellpadding="0" cellspacing="5" id="tmenu"> 
  <tr><td><a href="001.html" class="amenu">MENU001</a></td></tr>
  <tr><td><a href="002.html" class="amenu">MENU002</a></td></tr>
  <tr><td><a href="003.html" class="amenu">MENU003</a></td></tr>
  <tr><td><a href="004.html" class="amenu">MENU004</a></td></tr>
  <tr><td><a href="005.html" class="amenu">MENU005</a></td></tr>
</table>

 

CSS

#tmenu {
  float: left;
  width: 200px;
  position: fixed;
  margin: 10px;
}
#main {
  padding-left: 240px;
}
.amenu {
  background-color: #CCFFCC;
  color: #006600;
  font-weight: bold;
  display: block;
  padding: 5px;
  text-align: center;
  text-decoration: none;
}
.amenu:hover {
  background-color: #FFCCFF;
  color: #FF0000;
}

監修してくれたメンター

大堀 翔一郎(おおほりしょういちろう)

IT商社にてコーポレートサイト、ブランドサイトのディレクター兼デザイナー兼コーダー。

大学卒業後、WEB制作会社にでデザイナーとして入社し大手企業のサイト制作やブランドサイトの制作に携わってきました。

 

大石ゆかり

内容分かりやすくて良かったです!

田島悠介

ゆかりちゃんも分からないことがあったら質問してね!

大石ゆかり

分かりました。ありがとうございます!

TechAcademyでは、初心者でもオリジナルWebサイトを公開できるオンラインブートキャンプWebデザイン講座を開催しています。

挫折しない学習方法を知れる説明動画や、現役エンジニアとのビデオ通話とチャットサポート、学習用カリキュラムを体験できる無料体験も実施しているので、ぜひ参加してみてください。