css background-image サイズ

CSS 背景画像サイズ:背景画像のサイズを正確に制御する

この記事では、CSSのbackground-sizeプロパティについて詳しく説明し、背景画像のサイズを正確に制御して、さまざまな背景効果を実現する方法を紹介します。

background-size プロパティ値の詳細

background-sizeプロパティは、背景画像のサイズを指定するために使用します。以下の値を指定できます。

説明
cover 画像を拡大縮小して、背景領域全体を覆うように表示します。画像のアスペクト比は維持されますが、一部が切り取られる場合があります。
contain 画像を拡大縮小して、背景領域内に完全に収まるように表示します。画像のアスペクト比は維持されますが、余白ができる場合があります。
長さ 背景画像の幅を指定します。単位は、pxem%などを使用できます。
長さ 長さ 背景画像の幅と高さをそれぞれ指定します。1つ目の値が幅、2つ目の値が高さになります。
auto デフォルト値です。画像の元のサイズで表示されます。

使用シーンと例

フルスクリーン背景の作成

background-size: cover; を使用すると、画像を拡大縮小して背景領域全体を覆うことができます。これは、Webサイトのホームページやログインページの背景によく使用されます。


<style>
  body {
    background-image: url('background.jpg');
    background-size: cover;
  }
</style>

画像のアスペクト比の維持

background-size: contain; を使用すると、画像を拡大縮小して背景領域内に完全に収まるように表示できます。これにより、画像の変形を防ぐことができます。これは、ロゴやアイコンを表示する場合に適しています。


<style>
  .logo {
    background-image: url('logo.png');
    background-size: contain;
    background-repeat: no-repeat;
    width: 200px;
    height: 100px;
  }
</style>

カスタム背景サイズの指定

長さまたはパーセンテージを使用して、背景画像のカスタムサイズを指定できます。たとえば、 background-size: 500px 200px; または background-size: 50% 80%; を使用できます。


<style>
  .custom-background {
    background-image: url('pattern.png');
    background-size: 50% 80%;
  }
</style>

他の background プロパティとの併用

background-size プロパティは、他の background プロパティと組み合わせて使用できます。

  • background-repeat: 背景画像の繰り返し方法を制御します。
  • background-position: 背景画像の位置を設定します。

ブラウザの互換性

background-size プロパティは、主要なブラウザで広くサポートされています。

まとめ

background-size プロパティは、背景画像のサイズを強力に制御できるため、さまざまな属性値を柔軟に使用することで、さまざまな背景効果を簡単に実現し、Webページのデザイン性とユーザーエクスペリエンスを向上させることができます。

関連QA

Q1: background-size: cover; と background-size: contain; の違いは何ですか?

cover は画像を拡大縮小して背景領域全体を覆いますが、 contain は画像を拡大縮小して背景領域内に完全に収まるように表示します。

Q2: background-size プロパティでパーセンテージを使用する場合、何を基準に計算されますか?

パーセンテージは、親要素の幅と高さを基準に計算されます。

Q3: background-size プロパティが効かない場合はどうすればよいですか?

考えられる原因としては、以下の点が挙げられます。

  • DOCTYPE宣言がされていない
  • HTMLの構造が正しくない
  • CSSの記述に誤りがある
  • ブラウザのキャッシュが残っている

これらの点をチェックして、問題を解決してください。

その他の参考記事:CSS 背景プロパティ