We are ACORN!

プログラムやサーバーの設定など、技術的な記事を載せております。

HTMLコーディング プログラミング

画像の下に空く謎の隙間

投稿日:

HTMLのコーディングをしていると、画像の下に隙間が空いていることに気づくことはありませんか?
対処方法は知ってはいても、なぜ隙間が空くのか考えてみると面白いです。

画像の下に隙間が空く

事例:
https://jsbin.com/nimedav/edit?html,css,output

divの中にimgが入っていて、divの内部は100pxの大きさがあります。
そしてこの画像は正方形なので、隙間ができるはずがないように思えます。

でも実際は以下のように下に隙間が出てしまいます。

これを対処する方法はいくつかあります。

(1)
imgタグにvertical-align: topvertical-align: bottomを付けます。

(2)
imgタグをdisplay: blockでブロック要素に変えます。

なぜ画像の下に隙間が空く?

imginline-blockのような振る舞いをします。
つまり文字と横並びになります。

そうすると、以下のように画像と文字が横に並びます。

この時注目するのは、画像の下の余白とgの文字の下のでっぱり部分です。
abcと違ってgは下に出っ張ります。そのための余白が文字の下にあらかじめ設けられているわけです。

これは画像にも影響します。
なぜならvertical-align(行ボックスの中でインラインやインラインブロックの垂直方向配置方法)がbaselineになっていて、それはinline-blockにも影響を与えるからです。

よって、画像に対してvertical-align: topvertical-align: bottomを設定することでbaselineから生まれる隙間が無くなるわけです。

同様にimgdisplay: blockにしてしまえば、vertical-alignの影響は受けないので、隙間が無くなります。

 

調べてそのまま使うのもいいんですが、こうして仕組みを知っておくなら、vertical-alignを少し理解でき適切に利用することができるでしょうね。

-HTMLコーディング, プログラミング


comment

メールアドレスが公開されることはありません。 が付いている欄は必須項目です

日本語が含まれない投稿は無視されますのでご注意ください。(スパム対策)

関連記事

【PHP】 Macからの日本語名ファイルを正しく扱う

久しぶりに仕事ではまりました。 ファイルをアップロードして、その日本語名を利用するシステムなのですが、Macも含まれます。 それで、会社からMac miniを借りてダウンロード、アップロード実験をして …

【WSL】PHPから送信するメールをテキストに保存する

テスト環境で使っていると、PHPのメール送信をテストしたい時があります。 かといって、実際に送信されてしまうと面倒です。 xamppにはmailtodiskというのがあり、メールをディスクに保存してく …

【PHP】 全角記号のときmb_strwidthが1を返す

PHPで全角の判断に、mb_strwidthを使っていました。 mb_strwidth == (mb_strlen*2) だったら全角文字、みたいな。 そうしたら、「◎」を入れたらうまくいかないとクラ …

PHP Toolkit のSoapClientが接続できない

クライアントがPHPのバージョンを5.4から5.6にアップデートしたそうです。 (そういう時は前もって連絡ください(怒)) その際、エラーが出るというのです。 ログを見ると、 SoapClientの_ …

CSS3

Perfect Pixel で調整してみよう!

皆さんはPerfect PixelというChromeの拡張機能をご存じでしょうか? デザインカンプを半透明にしてWebページに重ね、要素のズレなどを確認できるものです。 そんなに厳密にWebページを作 …