CSS Tricks: @media
Using the same content on a website and on a printed document is a very common requirement. Even when the two versions share most of the style, it’s often useful to define some specific details for one of the supports using media types.
html {
background: #ddd;
}
@media print {
html {
background: transparent;
}
}
This example shows that a page with a light grey background. If this background is nice when displayed on a browser, where designers sometimes try to avoid pure black and white, it would require a lot of useless ink on paper for a bad result. Let’s set a transparent background, only for the printed document!
data:image/s3,"s3://crabby-images/ce50e/ce50ebbeea5f8d694ca4cbb64b5c7873584aa720" alt="Website view Website view with light grey background"
data:image/s3,"s3://crabby-images/791ce/791cefe752387d6597e49b7a7a7e998395532ca4" alt="Print view Print view with transparent background"
The media types give the possibility to use a single stylesheet, with rule mixed for different supports. But they also give nice syntaxes to split the stylesheets into different files, either using HTML:
<link href="print.css" rel="stylesheet" media="print">
Or CSS:
@import "print.css" print;
Learn more about media types: