WordPressを用いたホームページ制作はお任せください!岡山県を中心に絶賛活動中!
  • 背景画像をレスポンシブに対応させる方法

背景画像をレスポンシブに対応させる方法

oy151013249932_tp_v-2

背景画像をレスポンシブに対応させる方法をご紹介します。paddingを指定して横幅と縦幅の比率を保持したまま、背景画像を縮小拡大する方法です。3分間です。3分間で背景画像をレスポンシブに対応させる方法をマスターできます。

この記事は約 4 分で読めます。

レスポンシブと背景画像の関係

レスポンシブサイトで背景画像を利用してみると、困ってしまう事があります。

背景画像はその画像の高さを表示させるエリアに指定しないと画像の全てが表示されませんが、高さを指定してしまうと、デバイスの横幅が変った時に高さ分の余白や画像切れが生じてしまうのです。

背景画像をレスポンシブに対応させるときは、【background-size: contain;】などで横幅に合わせて画像を拡大縮小させるのが一般的かと思いますが、この時、背景画像を表示させるエリアに高さを指定していると、例えばスマホでサイトを観覧するとデバイスの横幅に合わせて画像は縮小されますが、そのエリアの高さは変わりませんので、余白が生じてしまうのです。

このままでは、スマホでサイトを観覧すると変に余白が出来てしまうので、デザインが崩れているように見えてしまいます。

この問題に直面した時、かなり困ってしまいました。
結構な時間を費やしたことを覚えています。

最終的に解決策が見つかりましたので、この場でシェアします。
その解決策は次の通りです。

背景画像を縦横の比率を保ったまま拡大縮小させる方法

解決方法は【高さを指定せずに背景画像を表示させる】でした。
どうするのかというと【paddingの余白】を利用します。

まず大前提として、背景画像を表示させるエリアに【height: 0;】を指定しておきます。
高さが0ですからこの時点では背景画像は表示されません。

次に【paddingの余白】を指定していきますが、レスポンシブ対応ですので余白は%で指定します。

padding-topに指定する数値は、以下の計算式で算出します。

高さ÷横幅×100=padding-topの%(パーセント)

例えば、画像の横縦のサイズが、700×300pxだった場合ですと・・・

300÷700×100=42.857・・・

四捨五入して【43%】が【padding-top】の数値となります。

サンプルのHTMLとCSSをご確認ください。

<div id="background"></div>
#background {
width: 100%;
height: 0;
padding-top: 43%;
background-image: url(画像パス);
background-size: contain;
}

この様にすると、以下のように背景画像がレスポンシブに対応されます。

PCで確認されている場合、ウィンドウの横幅を縮小や拡大してみてください。
スマホで確認している場合は、デバイスの向きを縦向きや横向きに変えてみてください。

背景画像がデバイスの横幅に合わせて縮小拡大され、なおかつ高さに余白ができないことがご確認いただけるかと思います。

まとめ

背景画像をレスポンシブに対応させる方法をご紹介しました。

背景画像をレスポンシブに対応させるなら、今回ご紹介した方法が簡単かつ機能的かと思います。
ただ、若干ですがどうしてもズレが生じる場合があります。

ここが我慢するしかないですかね。
そこまで目立つズレでもありませんから。

シェアしていただきありがとうございます。

oy151013249932_tp_v-2

この記事が気に入ったら【いいね】しよう!

著者:とあるWEBディレクター

岡山在住のWebディレクターです。Wordpressを使ったWEBサイト制作を中心に7年間ほど活動させていただいています。

Wordpress関連の記事でお役に立てれば幸いです。

【関連記事】あなたが興味のありそうな関連記事をご紹介します。

  • img_center

    CSSで特定の画像だけを中央揃えにする方法

    画像を設置するブロックをセンタリングすることなく特定の画像だけを中央揃えにする方法をご紹介しています。あまり需要はないかもしれませんが、どなたかの参考になるとうれしいですね。 記事を読む

  • film-589490_1280

    予想以上に簡単だった!YOUTUBE動画のサムネイルを取得する方法

    YOUTUBE動画のサムネイルを取得する方法をご紹介します。YOUTUBEの様々なサイズのサムネイルを取得したい方に向けたコンテンツです。2分後にはお好きなサイズのサムネイルを自由に取得できるようになります。 記事を読む

  • Green6_huropc20141123161454500

    【SEO対策】text-indent:-9999pxを使わずテキストを画像に置換する方法

    text-indent:-9999pxを用いて、テキストを画像に置換する手法をご存知でしょうか?この手法、便利なのですが、SEO的に不利だと言われています。そこで今回は、text-indent:-9999pxを使わずテキストを画像に置換する方法をご紹介いたします。 記事を読む

  • bsYUKA862_megane15205354

    これで一発解決!固定ナビゲーションのページ内リンクのズレを解消

    固定ナビゲーションのページ内リンクがズレてしまう現象を解消する方法をご紹介します。固定ナビゲーションとページ内リンクを合わせて使うと、遷移する位置が思った場所よりズレしまうことがあります。そんな時の解決方法を2分程度で知ることができます。 記事を読む

  • MAX88_suwaipu20141025133450500 (2)

    スマホを横向きにした時、WEBサイトの文字サイズを勝手に変更させない方法

    スマホの縦向きと横向きでWEBサイトの文字サイズを勝手に変更させない方法をご紹介しました。文字サイズを変えたくないという方もいると思います。1回のコピペで実装できますので試してみてください。 記事を読む

コメントを残す


(必須)

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