カテゴリ: CSS 更新日: 2026/01/28

CSSの背景画像とグラデーションを組み合わせる方法!初心者にもわかる完全解説

グラデーションと画像を組み合わせた背景デザインの作り方
グラデーションと画像を組み合わせた背景デザインの作り方

先生と生徒の会話形式で理解しよう

生徒

「CSSで背景に画像を入れる方法はわかってきたんですが、グラデーションと一緒に使うことはできますか?」

先生

「はい、できますよ!CSSでは、背景画像とグラデーションを組み合わせて、オシャレなデザインを作ることができるんです。」

生徒

「どうやって設定すればいいんですか?コードが難しそう…」

先生

「大丈夫!丁寧に説明していくので、一緒にやってみましょう。」

1. 背景画像とグラデーションの基本的な仕組み

1. 背景画像とグラデーションの基本的な仕組み
1. 背景画像とグラデーションの基本的な仕組み

CSS(シーエスエス)では、背景に画像(例えば海や空の写真)を設定するだけでなく、色の変化(これを「グラデーション」と言います)も組み合わせて使うことができます。

グラデーションとは、ある色から別の色に少しずつ変わっていく効果のことです。たとえば、青から白にゆっくりと色が変化するような背景を作ることができます。

この2つを一緒に使うと、「画像の上に半透明の色の層」をかぶせるような表現が可能になります。

2. 背景画像の上にグラデーションを重ねるには?

2. 背景画像の上にグラデーションを重ねるには?
2. 背景画像の上にグラデーションを重ねるには?

実は、CSSでは複数の背景を同時に指定することができます。その際、先に書いたものが一番上に重なります。

つまり、グラデーションを先に書くと、それが画像の上に乗るように表示されます。

3. 実際にコードを書いてみよう

3. 実際にコードを書いてみよう
3. 実際にコードを書いてみよう

それでは、具体的なHTMLとCSSのコードを見てみましょう。ここでは、グラデーションと背景画像を組み合わせて、優しい印象の背景を作ってみます。


<style>
.container {
    width: 100%;
    height: 300px;
    background-image:
        linear-gradient(rgba(255,255,255,0.6), rgba(255,255,255,0.6)),
        url('https://picsum.photos/id/1015/800/300');
    background-size: cover;
    background-position: center;
    display: flex;
    justify-content: center;
    align-items: center;
}

.container h2 {
    font-size: 2rem;
    color: #333;
    background-color: rgba(255, 255, 255, 0.8);
    padding: 10px 20px;
    border-radius: 10px;
}
</style>

<div class="container">
    <h2>グラデーション付き背景画像</h2>
</div>
ブラウザ表示

4. グラデーションと画像を重ねる順番に注意しよう

4. グラデーションと画像を重ねる順番に注意しよう
4. グラデーションと画像を重ねる順番に注意しよう

CSSでは、背景を複数指定するときに「カンマ(,)」で区切ります。そして、左に書いたものほど上に表示されます。

この例では、linear-gradient()が先に書かれているので、グラデーションが上に、画像が下に表示されているというわけです。

このようにすることで、背景画像に「ぼんやりとした光」や「半透明のフィルター」のような効果を加えることができます。

5. グラデーションの色や透明度を自由に変えてみよう

5. グラデーションの色や透明度を自由に変えてみよう
5. グラデーションの色や透明度を自由に変えてみよう

グラデーションの色や透明度(とうめいど)は自由に変更できます。以下のようにすると、青から透明になるグラデーションになります。


background-image: linear-gradient(rgba(0, 123, 255, 0.5), rgba(0, 123, 255, 0)), url("画像のURL");

このように、グラデーションの色と透明度をうまく使えば、見た目に優しく読みやすい背景デザインが完成します。

6. 背景画像のサイズと位置も調整しよう

6. 背景画像のサイズと位置も調整しよう
6. 背景画像のサイズと位置も調整しよう

背景画像がうまく表示されない場合は、background-sizebackground-positionのプロパティを使って調整しましょう。

  • background-size: cover; は、背景画像がコンテナのサイズにぴったり合うように拡大・縮小します。
  • background-position: center; は、画像の中心が常に表示されるようにします。

このように、背景の調整はとても大事なポイントになります。

7. よくある間違いと注意点

7. よくある間違いと注意点
7. よくある間違いと注意点

CSSで背景画像とグラデーションを同時に指定する場合、順番を間違えると意図した見た目にならないことがあります。

また、画像のURLが間違っていたり、透明度の設定が濃すぎると背景画像が見えなくなってしまうこともあります。

初めて書くときは、少しずつ色や値を変えて、実際に表示を確認しながら進めるのが安心です。

8. 背景デザインを上手に活かすコツ

8. 背景デザインを上手に活かすコツ
8. 背景デザインを上手に活かすコツ

背景にグラデーションと画像を組み合わせるときは、「テキストの可読性(読みやすさ)」を意識することがとても大切です。

背景がごちゃごちゃしていると文字が読みづらくなってしまうので、グラデーションで少し白っぽくすることでテキストがはっきり見えるようになります。

このテクニックは、Webデザインでもよく使われる方法です。ブログやランディングページ、バナー画像などにも応用できます。

まとめ

まとめ
まとめ

いかがでしたでしょうか。今回は、CSSを使って背景画像とグラデーションを巧みに組み合わせるテクニックについて詳しく解説してきました。Webデザインにおいて、背景に一枚の写真を置くだけでも印象は変わりますが、そこに「グラデーション」というレイヤーを重ねることで、一気にプロっぽく、そして実用的なデザインへと昇華させることができます。

ここまでの重要なポイントを振り返ってみましょう。まず、CSSの「background-image」プロパティは、カンマで区切ることで複数の要素を重ねて指定できるという点です。この際、記述する順番が非常に重要で、「先に書いたものが上(手前)に、後に書いたものが下(奥)に」配置されます。そのため、画像の上に色を乗せたい場合は、必ず「linear-gradient」を先に記述し、その後に「url()」を記述するというルールを忘れないようにしましょう。

また、グラデーションの色指定には「rgba」形式を活用するのがコツです。透明度(アルファ値)を0.1から0.9の間で微調整することで、下の画像をどの程度透けさせるかをコントロールできます。これにより、写真が鮮やかすぎて文字が読めないという問題も、白や黒の半透明グラデーションを被せることでスマートに解決できます。

さらに応用として、複数の色を組み合わせたり、方向を指定したりすることで、よりリッチな視覚効果を生み出すことも可能です。例えば、サイトのブランドカラーを薄く重ねれば、汎用的なフリー素材の画像であっても、自社サイト専用のオリジナル画像のような統一感を出すことができます。

応用編:実践的なオーバーレイ・デザイン

ここでは、実際のWebサイトのヘッダーなどでよく使われる、少し暗めのグラデーションを重ねて白い文字を際立たせる「ダークオーバーレイ」のサンプルを紹介します。視認性が格段に向上するので、ぜひ自身のプロジェクトに取り入れてみてください。


<style>
.hero-section {
	width: 100%;
	height: 400px;
	background-image:
		linear-gradient(135deg, rgba(0, 0, 0, 0.7) 0%, rgba(0, 0, 0, 0.3) 100%),
		url('/img/sample150-100.jpg');
	background-size: cover;
	background-position: center;
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	color: #ffffff;
	text-align: center;
	font-family: sans-serif;
}

.hero-section h1 {
	font-size: 2.5rem;
	margin-bottom: 10px;
	text-shadow: 2px 2px 4px rgba(0,0,0,0.5);
}

.hero-section p {
	font-size: 1.1rem;
}
</style>

<div class="hero-section">
	<h1>理想の景色をデザインする</h1>
	<p>CSSグラデーションと画像の組み合わせで、<br>あなたのウェブサイトはもっと美しくなります。</p>
</div>
ブラウザ表示

このように、背景設定ひとつでユーザーに与える「安心感」や「読みやすさ」は劇的に変化します。最初はコードの記述順序に戸惑うかもしれませんが、「上から順に重ねる」という基本さえ押さえれば、表現の幅は無限大です。ぜひ、自分なりの色の組み合わせを見つけて、魅力的なWebページを作成してみてください。

先生と生徒の振り返り会話

生徒

「先生、ありがとうございました!背景画像の上にグラデーションを置くときは、コードの順番が『上が先』っていうのが一番のポイントなんですね。」

先生

「その通りです。よく『画像が消えちゃいました!』と相談されるんですが、大抵は画像のurlを先に書いて、グラデーションを後に書いているのが原因なんですよ。画像が一番上にきちゃって、その下のグラデーションが隠れてしまっている状態ですね。」

生徒

「なるほど。あと、rgbaの最後の数字を変えるだけで、写真の透け具合が簡単に調整できるのも面白いです。さっきのダークオーバーレイ、すごくかっこよかったので自分のサイトでも使ってみます!」

先生

「それは嬉しいですね。背景が暗めなら白文字、背景が明るめなら黒文字、というようにコントラストを意識すると、さらに読みやすくなりますよ。他にもbackground-blend-modeというプロパティを使えば、もっと複雑な色の混ざり方も作れますが、まずは今回の基本をしっかりマスターしてくださいね。」

生徒

「はい!まずは基本の透明度調整から慣れていこうと思います。背景デザインが楽しくなってきました!」

2026年最新 スキルアップ・実践セミナー

【60分集中】Flexboxを完全攻略!最新CSS3で「崩れない・迷わない」モダンUI構築セミナー

「魅せる力」をコードで実現。CSS3でモダンWebデザインのプロトタイピングを。

本講座では、単に色を変えるだけではなく、「ユーザーを迷わせないUIデザイン」「崩れないレイアウト設計」の本質を学びます。最新のCSS3とモダンなレイアウト手法を通じて、プロの現場で通用する「美しさと機能性を両立した実装力」を最短距離で習得します。

具体的なワークショップ内容と環境

【つくるもの】
HTMLで作成した骨組みに対し、商用サイトでも採用される「スタイリッシュなカード型UI」や「レスポンシブなナビゲーション」を構築します。色の選定基準や余白(ホワイトスペース)の黄金比など、デザインの理論をコードに落とし込む工程を体験してください。

【開発環境】
フロントエンド開発の標準であるVisual Studio Code (VS Code)を継続使用。CSSの記述を効率化するプラグインや、ブラウザのデベロッパーツール(検証機能)を駆使して、リアルタイムでデザインを微調整するプロのワークフローを再現します。

この60分で得られる3つの技術資産

1. 現代のデファクトスタンダード「Flexbox」

要素の横並びや中央揃えを自由自在に操り、どんなデバイスでも崩れないレスポンシブな配置術を完全理解します。

2. メンテナンス性を高めるCSS設計の基礎

後から修正しやすい「壊れにくいコード」の書き方を伝授。プロの現場で必須となる命名規則の考え方を学びます。

3. パフォーマンスと美しさの両立

画像の最適化や軽量な装飾技法など、ページの表示速度を落とさずに高級感のある演出を行うテクニックを習得します。

※本講座は、HTMLの基礎を終えた後のステップアップ講座です。Webデザイナー、UIデザイナー、フロントエンドエンジニアへの道を切り開く「魅せる技術」を、モクモク独自のパーソナル指導で着実に定着させます。

【60分集中】Flexboxを完全攻略!最新CSS3で「崩れない・迷わない」モダンUI構築セミナー

リラックスしながら、学ぶことが大切です。しっかりと基礎を理解しましょう!

各回少人数・マンツーマン形式で徹底サポート

このセミナーの詳細・お申し込みはこちら
カテゴリの一覧へ
新着記事
New1
CSS
CSSのcolumn-countを完全ガイド!初心者でもわかる複数列レイアウトの作り方
New2
CSS
CSSのz-indexとposition完全ガイド!初心者でもわかる要素を重ねる方法
New3
Bootstrap
Bootstrapオフキャンバス入門:.offcanvasと.offcanvas-start・end・top・bottomの基本をやさしく解説
New4
CSS
CSSのoverflowプロパティ完全ガイド!初心者でもわかるvisible・hidden・scroll・autoの違い
人気記事
No.1
Java&Spring記事人気No1
CSS
CSSで文字の間隔を調整する方法!初心者でもわかるletter-spacingとword-spacingの使い方
No.2
Java&Spring記事人気No2
CSS
CSSで要素のサイズを自動調整!autoとfit-contentの使い方
No.3
Java&Spring記事人気No3
CSS
CSSのmarginとpaddingの違いとは?初心者でもわかるボックス間のスペース調整の基本
No.4
Java&Spring記事人気No4
Bootstrap
Bootstrap Iconsのライセンスと商用利用の注意点【著作権と表記を初心者向けに解説】
No.5
Java&Spring記事人気No5
CSS
CSSのoverflowプロパティ完全ガイド!初心者でもわかるvisible・hidden・scroll・autoの違い
No.6
Java&Spring記事人気No6
CSS
CSSの文字色と背景色をやさしく解説!初心者でもわかる基本の設定方法
No.7
Java&Spring記事人気No7
HTML
HTMLのliタグとは?初心者でもわかるul・ol内での正しい役割を完全解説
No.8
Java&Spring記事人気No8
CSS
CSSの状態によるセレクタ完全ガイド!初心者でもわかる:checkedと:disabledの使い方