★メニューのサイズを指定する

当サイトのリンクからサインアップしても、利用者の方に追加料金はかかりませんが、私たちが紹介手数料を受け取る場合があります。

メニューのサイズを指定する

広告



ここから数回は、CSSでメインメニュー部分のスタイリングをしていきます。
HTMLソースはそのままに、CSSの指定のしかた次第で見栄えが大きく変化することを実感してください。

まず、CSSでメインメニューのサイズを指定しましょう。
base.cssに以下の記述を追加してください。

CSSソース(base.css)

@charset "utf-8";
body {
	font-size:95%;		/* フォントサイズを95%にする */
	font-family: "MS ゴシック",sans-serif;	/* フォントの種類をゴシック系にする */
	line-height:1.5;	/* 行の高さを1.5倍にする */
	color:#333333;		/* 文字色を濃い目のグレーにする */
}

/*============================================
メインメニュー
============================================*/
ul#menu {
	width:960px; height:50px; 	/*メインメニュー部分の幅と高さ*/
}
#menu li {
	list-style-type:none;		/*リストマーカー無しにする*/
	display:inline;			/*リスト項目をインライン表示にする*/
	float:left;			/*リスト項目を横に並べる*/
}
#menu li a {
	display:block;			/*リンク部分をブロック表示にする*/
	width:240px; height:35px;	/*幅と高さ*/
}

保存をしたらブラウザで表示してみましょう。
メインメニュー部分のサイズが拡がり、クリックできるリンク範囲が広くなれば成功です。

上記のCSSソースを、いくつかの部分に分けて見ていきましょう。

メインメニュー全体の幅と高さを指定する

width:960px; height:50px; は、メインメニュー全体を横幅960、高さ50ピクセルに指定しています。

ul#menu { ~ } というセレクタは、「menuというid名を付けられているul要素」をスタイル適用の対象にするということです。
このul要素のサイズがメインメニュー全体のサイズとなります。
この範囲内に各メニュー項目のリンク部分を収めていくことになります。

クリックできるリンク範囲を広くする

display:block; は、各メニュー項目のリンク部分となるa要素の表示形式をブロック表示にしています。
この指定により、リンク部分の幅と高さをブロック状に固定することが可能になります。
width:240px; height:35px; で、a要素のサイズを240×35ピクセルにすることで、クリックできるリンク範囲を広くしています。

リストをフロート配置にする

a要素をブロック表示にすると、メニューリンクがひとつひとつ改行されて縦メニューになります。
これを横メニューにするために、float:left; の指定でli要素をフロート配置にして横に並ぶようにしています。

フロート配置とは、要素の配置を浮遊状態にしてしまう配置スタイルのことです。
フロート配置になった要素は、他の要素に対して浮いたような状態となります。
前の要素がフロートして左に寄せられると、後に続く要素は空いたスペースを埋めるように配置されます。

フロート配置におけるカラム落ち

上記のスタイル指定では、a要素のサイズを固定して、さらにそれをフロート配置にして横に並べました。
この際、注目して欲しいのは、親要素となるul要素の横幅を960px、a要素の横幅を240pxと指定している点です。

横に並べるa要素は4つですから、横幅が240px×4=960pxとなって親要素の横幅と同じになります。
子要素となる4つのa要素の横幅の合計が、親要素の横幅を超えていないためにうまく横に並んでいられるのです。

試しに親要素の横幅を959pxにして(1ピクセル小さくして)、表示確認をしてみましょう。

最後のa要素が親要素の範囲に入りきらずに改行されてしまっています。
この状態をカラム落ちと言います。
カラム落ちが分かりやすいように、背景画像の付いた状態で比べてみましょう。

ul要素の横幅960pxの場合にはカラム落ちしない

ul要素の横幅959pxの場合にはカラム落ちが起きる

横に並べるa要素の横幅の合計960pxが、親要素となるul要素の横幅959pxを超えてしまったために、カラム落ちが起きたのです。

まとめ
  1. 要素の横幅と高さは、widthプロパティとheightプロパティで指定する
  2. a要素をブロック表示にすることで、クリックできるリンク範囲を広くする
  3. リストをフロート配置にすることで、メニュー項目を横に並べる
<前へ 目次へ 次へ>

広告



山田 太郎
テック・リード
山田太郎は、ウェブ開発やグラフィックスプログラミングに10年以上の経験を持つテクノロジーの専門家です。特にHTML5 CanvasやJavaScript、インタラクティブメディアに精通しており、動的なユーザーインターフェースや最先端のウェブアプリケーションの開発に携わってきました。複雑な図形描画や画像操作、リアルタイムグラフィックスに関する知識が豊富で、ウェブ技術の限界を追求する開発者たちにとって頼りになる存在です。知識の共有に情熱を持ち、初心者からプロフェッショナルまで幅広く支援するため、技術フォーラムやブログにも積極的に貢献しています。

ギャンブルガイド もっと見る

カジノファインダー

どのカジノが自分に最適か分からないですか?

サインアップは必要なく、1 分以内に最適なブックメーカーを簡単に見つけることができます。
カジノを探す
Back
質問
Select one of the following options
{"is_any_tile":true}

どのカジノが自分に最適か分からないですか?

Back
Restart
やったー!
これはあなたの選択に基づいた最高のカジノです...
67 users signed up
もっと表示する