Web.fla

主食は、html/css/php/javascript(jQuery) デザートはactionscript!WEBに関することをメモってくサイト

*

【CSS】画像をスマホ対応!!ウィンドウに合わせて自動で拡大・縮小させるには?!

      2016/08/29

ここ最近はスマホが主流になってきているのでレスポンシブなWEBサイトを作ることも多いと思います。
そんな時に画像のサイズって悩んだりしません?

例えばトップページだとメインの画像がファーストビューにあってスマホで見ると画像がはみ出しちゃってるとか・・そんな、悩みをCSSでウィンドウに合わせて自動的にリサイズさせれば簡単にスマホに対応できるよね♪っていうのが今回の目的です。まずは下記にサンプルを作りました。

画像のサイズがスマホにあっていない例として

スマホ用に最適化されていないとレイアウトがおかしいことになってしまう例として

  • スマホで見ると画像が大きすぎてはみ出しちゃってる

他にも色々ありますが、画像のサイズが最適化されていないと、レイアウトが崩れてユーザーにも非常に見にくいサイトになってしまいますよね。
では、これをCSSで解決してきます。

ウィンドウサイズに合わせて画像サイズを自動で伸縮させる

ではスマホはもちろんウィンドウサイズに合わせて画像を縦横比を維持したまま伸縮させたいと思います。

CSSでimgタグにmax-widthを設定する

全部もしくは該当するimgタグに「max-width: 100%」を設定する事で、画面幅に合わせて自動で幅を調節させる事が可能であり、「height:auto;」を指定する事で画像の拡大・縮小に合わせて、縦横比を保持できます。たったこれだけです!

普通のwidthだとダメなの?

画像にCSSで「max-width」を設定する事で対応しましたが、「width:100%」にすると拡大・縮小にも対応してくれます。
ただ常に100%表示されてしまうので、仮に元の画像が800pxだとしてもウィンドウの幅が1200pxだとしたらそれに合わせて画像も100%で表示されるので800px以上になってしまい元の画像サイズを超えてしまい画像が伸びてしまうので注意が必要です。

max-widthが効かない場合の対処方とは

IEもしくはFirefoxでCSSの「max-width」が効かない事があるそうです。その原因と対処法です。

max-widthが効かない原因とは?

IEとFirefoxで効かない原因は、親要素のCSSで「display:table」となっていて子要素が「display:table-cell」になっている場合はmax-widthが効かないようです。

html

CSS

対処法はCSSをひとつ追加するだけ

max-widthが効かない時の対処法は、「display:table」を指定している要素に対して「table-layout: fixed」を指定するだけです。

これで、問題なくmax-widthが効くので画像がウィンドウに合わせて伸縮するようになります。

 - css

     

Message

  関連記事

cssで幅を指定しない要素を横並びにする

ちょいちょい忘れるんでメモ。良く画像とテキストの横並びさせることがあるが、個人的 …

【CSS】一行でテキストを左右に分けるときのCSS

よくタイトルバーなどで左側にタイトルで右側に日付なり「続きはこちら」のようにテキ …

CSS3のFlexboxが仕様が変わった!!新しいフレキシブルボックスレイアウトとは!?

CSS3のフレックスボックスなんですが、もともとフレックスボックスに対する査定が …

CSS3で写真風に装飾をするには!?

最近は、各ブラウザもCSS3に対応してきてるので割と装飾もCSS3でやってしまお …

CSSで動画をレスポンシブに対応させる方法

最近、スマホが主流になってきてyoutubeやVimeoなどの動画を埋め込むサイ …

【CSS】のinline-blockで要素を横並びにしてみた!

今更の話ですが、ナビゲーションを作成するときは、結構「float」を利用して横並 …

【CSS】チェックボックスとテキストを水平にしたい

皆さん、フォームをマークアップするときにこんな経験ありませんか? フォームのラジ …

CSSで写真をテープで止めた様な装飾をしてみた

たまに見る、写真をセロテープで止めた感じの画像の見せ方。以前は画像でしたが、CS …

CSS3のbox-ordinal-groupで順番を入れ替える

前回は主にフレックスボックスについてメモしたけども、基本的にはフレックスボックス …

【CSS3】新しいプロパティで要素を上下中央に配置する方法!!

ここ最近は、CSS3もだいぶ使えるような環境が整ってきたのですが、少し要素を上下 …