• HOME > 
  • CSS > 
  • 背景が印刷できないときにCSSで指定する方法【初心者にもわか...

背景が印刷できないときにCSSで指定する方法【初心者にもわかりやすく解説】

投稿日:

このページにはGoogleアドセンス広告とアフィリエイト広告が含まれています。

カテゴリー記事のアイキャッチ画像

本記事は執筆時点(2022年01月21日)の情報をベースにしております。掲載している情報が最新ではない可能性がありますので何卒ご容赦ください。

広告
広告

ページ内で背景だけが印刷されない原因

ページを印刷したときに、背景色や背景画像が印刷されない場合があります。

実はブラウザの印刷設定には、「背景のグラフィック」を印刷するか選択する項目が存在し、これが無効化されているとbackgroundプロパティのスタイルが印刷されなくなってしまいます。

背景とは、CSSのbackgroundプロパティに指定したスタイルを指します。

imgタグではなく、backgroundプロパティを利用して画像を表示している部分も該当します。

例えば以下のように制作したページがあるとします。

CSS

.sample .header{
  background:#999;
  border:solid 3px #666;
  padding:10px;
  margin:30px 0;
  color:#00f;
  font-weight:bold;
}
.sample .footer{
  background:#c9c9c9;
  border:solid 3px #b9b9b9;
  padding:10px;
  margin:30px 0;
  color:#f00;
  font-weight:bold;
}
.sample th,.sample td{
  width:50%;
  height:100px;
  padding:10px;
  vertical-align:middle;
}
.sample th{
  background:url(forest.jpg)center no-repeat;
}

HTML

<div class="sample">
  <div class="header">サイトタイトル</div>
  <table><tr>
  <th>テスト</th><td>ダミーテキストダミーテキストダミーテキストダミーテキストダミーテキストダミーテキスト</td>
  </tr></table>
  <div class="footer">フッター</div>
</div><!--end sample-->

ブラウザでは下図のように表示されているのに、

ブラウザでの表示例

印刷してみると下図のように印刷されてしまう場合があります。

背景が印刷されない例

ブラウザの印刷設定を確認する

backgroundプロパティまで印刷するには、ブラウザの印刷設定を変更します。

Google Chromeの場合

印刷プレビューの画面から、「詳細設定」の中にある「背景のグラフィック」にチェックを入れます。

Chromeの場合

Microsoft Edgeの場合

印刷プレビューの画面から、「その他の設定」の中にある「背景のグラフィックス」にチェックを入れます。

Edgeの場合

Internet Explorerの場合

印刷プレビューの画面から上部の設定ボタンをクリックし、開いた「ページ設定」ウインドウの「用紙オプション」にある「背景の色とイメージを印刷する」にチェックを入れます。

IEの場合

CSSで制御する方法

自身で印刷する際は前述の内容を理解していれば問題ありませんが、サイトを訪れ、印刷しようとしたユーザーが皆理解している訳ではありません。

せっかく制作したサイトが不完全に印刷されてしまうだけでなく、サイト側に問題があるから印刷できないのだと考えるユーザーもいるかもしれません。

CSSには印刷時に必ず背景まで印刷されるように強制するプロパティが存在します。

前述のような問題を未然に防ぐためにもCSSであらかじめ指定しておきましょう。

-webkit-print-color-adjustプロパティ

CSS

@media print{
 *{
     -webkit-print-color-adjust: exact;
 }
}

記述の説明

印刷するときだけ必要になりますので、メディアクエリ(@media print)の中に記述しています。

セレクタ「*」は全ての要素を指します。このように指定することで、backgroundとセットで何度も記述する必要はなくなります。

なお、 -webkit-print-color-adjustは、Google ChromeとMicrosoft Edge限定で使用できるプロパティです。

リンク先のサムネイル
CSSのベンダープレフィックスとは?【初心者にもわかりやすく解説】

ベンダープレフィックスをプロパティの接頭辞として付与して記述することで、各ブラウザのベンダー(開発元)が開発した拡張機能のCSSを先行実装できるようになります。べンダープレフィックスにはブラウザごとの接頭辞が存在します。使用する時はプロパティ名の前にハイフォンをつけて記述します。  ...【もっと読む】

残念ながらInternet Explorerでは、非対応となっていますので、前述のようにブラウザの印刷設定で背景も印刷するようにチェックを入れる必要があります。

まとめ

サイト制作においては印刷した際の状態の確認は見落としがちです。簡単に対応できますので、あらかじめ記述しておいた方が良いかもしれません。

広告
広告

関連する記事

サムネイル

CSSの疑似クラスnth-childとnth-of-type……

2024年11月07日
疑似クラスnth-childとnth-of-typeについて CSSの疑似クラス「:nth-child」と「:nth-of-type」はどちらも何番目の要素とい […]
サムネイル

CSSのみでスムーススクロールを実装する【scroll-be……

2024年08月01日
スムーススクロールはCSSだけで実装できる? これまでスムーススクロールはJavaScriptで実装するものと思い込んでいたのですが、先日ふとしたきっかけで、C […]
サムネイル

CSSのinline-flexの使いどころ【flexによる横……

2024年05月29日
inline-flexはCSSのdisplayプロパティの値の一つで、横並びレイアウトを作ることができる「flex」にインライン効果を持たせた性質があります。
サムネイル

CSSのセレクターで前方一致や部分一致を使って指定する方法

2024年05月16日
CSSでは属性の値を前方一致や部分一致でセレクターに指定できます。IDやクラス以外のhrefといった属性値であれば指定できるので、例えばリンク先ごとに処理を変えることも可能です。
サムネイル

CSSでテーブルの先頭行や先頭列を固定する方法【sticky……

2024年04月12日
CSSのpositionプロパティの「sticky」を使えば、CSSだけでテーブルの行も列も簡単に固定することができるのでご紹介します。情報量の多い表を作る場合は、スクロールした時に項目名などの行や列は固定させておいたほうが見やすくなります。
サムネイル

CSSのwhite-spaceプロパティの使い方【半角スペー……

2024年03月07日
SSのwhite-spaceは、テキストにおける半角スペース・改行・タブの扱いと折り返しの有無を設定するプロパティです。
サムネイル

CSSのメディアクエリでスマホでのホバーの挙動の対策を行う【……

2023年10月01日
最終更新日:2023年09月28日
要素をタップしたときにホバー時のスタイルが適用され続けるという経験はありませんか?CSSだけで簡単にスマホでの疑似要素「hover」の挙動の対策を行う方法をご紹介します。