谷歌地图过去常常这样做,当您点击“打印”链接时,发送到打印机的内容并不完全是您在屏幕上看到的内容,而是大部分相同信息的不同格式版本。
似乎他们在很大程度上已经远离了这个概念(我猜人们不理解它)并且大多数网站都有文章等内容的“印刷版”。
但是,如果您想制作一个网页,以便将页面的“打印机友好”版本发送到打印机,而无需为其制作单独的页面,您将如何做到这一点?
您可以通过创建一个直接针对打印的 CSS 样式表和另一个直接针对屏幕的 CSS 样式表来实现此效果。
使用链接标签:
<link rel="stylesheet" type="text/css" href="print.css" media="print, handheld" />
<link rel="stylesheet" type="text/css" href="screen.css" media="screen" />
将您的样式表嵌入到您的文档中。
隐藏很容易,只需将您的块样式设置为隐藏在您想要的任何样式表中,它就不会显示。例如:
.newStyle1 {
display: none;
}
然后任何设置为样式的内容newStyle1
都不会显示。
CSS 中的@media
规则可用于定义打印的替代规则。这通常用于隐藏导航和更改样式以更好地适应打印:
@media print {
.sidebar { display: none; }
}
您还可以链接单独的样式表进行打印:
<link rel="stylesheet" href="print.css" type="text/css" media="print" />
当您将媒体指定为打印时,您可以使用 css 执行此操作。
使用打印样式表。
编辑:关于后续操作,一般来说,您不能使用 CSS 将内容添加到页面中。
一种选择是在页面中包含您的仅打印内容,并为屏幕样式表隐藏它。你应该确保页面在没有 CSS 的情况下仍然有意义。
另一种选择是使用生成的内容,但这不受 Internet Explorer 7 及更低版本的支持,并且可能非常有限。
如果仅打印内容是图像,您可以使用一种流行的图像替换技术将其交换出来。
如果需要,另一种方法是让页面上的“打印”按钮以您决定的某种方式更改页面,然后执行 javascript 'window.print();' 调出浏览器的打印对话框。
有几个选项可供您使用:
例如<link href="css/print.css" type="text/css" rel="stylesheet" media="print" />
另请参阅CSS2 打印参考
最简单的方法是使用 CSS 媒体类型。对于您包含的每个 CSS 文件,您可以指定应该在哪里使用它:屏幕上、打印时、手持设备、屏幕阅读器或这些的各种组合。
示例:<link rel="stylesheet" type="text/css" media="print,held" href="foo.css">
这是自 CSS2 以来的标准,现在大多数浏览器都支持它。更多信息可在此处获得:http ://www.w3.org/TR/CSS2/media.html
CSS 允许您为特定类型的媒体创建样式表,这意味着您可以拥有一个仅在打印页面时应用的样式表,从而允许您对其进行不同的格式设置。
只需在该样式表的样式表链接上包含一个 media="print" 属性。
这篇A List Apart 文章在这个主题上似乎相当不错。
我尝试根据媒体使用不同的样式表,但在获取所需的所有选项时遇到了麻烦。从那时起,我通常会重定向到我们 (Fusebox) 框架的不同入口(即 print.php 而不是 index.php ) 本质上是同一个文件,只是它设置了一个额外的标志/常量。
然后,在与页面关联的 XSL 文件中,我根据该标志/常量进行额外的工作,例如省略菜单、表格的列等。
即(页面显示用户必须单击才能在屏幕上显示密码的链接。打印版本已打印密码。)
if (!BOOL_PRINT)
echo "<TD class=\"tbl_teams_scroll_item\"><SPAN class=\"span_password_hidden\" id=\"span_password_{\$team_id}\" onClick=\"RevealPassword('{\$team_id}','{\$password}');\"><xsl:value-of select=\"/PAGE/TEXTS/HIDDEN\" /></SPAN></TD>\n";
else
echo "TD class=\"tbl_teams_scroll_item\"><xsl:value-of select=\"PASSWORD\" /></TD>\n";
您可以定义特定于媒体类型的 css 规则。下面是一个 css 示例(从http://www.w3.org/TR/CSS2/media.html中复制,第 7.2.1 节),它指定了不同的字体大小在网页上显示的内容和打印的内容。
@media print {
BODY { font-size: 10pt }
}
@media screen {
BODY { font-size: 12pt }
}
@media screen, print {
BODY { line-height: 1.2 }
}
或者,您可以指定将样式表包含在页面中时应应用于哪些媒体:
<link href="webstyles.css" type="text/css" rel="stylesheet" media="screen"/>
<link href="printstyles.css" type="text/css" rel="stylesheet" media="print"/>
<link href="commonstyles.css" type="text/css" rel="stylesheet" media="screen,print"/>
另一种选择是拥有一个隐藏的 IFRAME,您可以在其上调用 iframe.contentWindow.print()。这将允许您创建一个完全按照您想要的方式打印的不可见布局。
当然,更好的解决方案是将文件导出为 PDF 并让用户以这种方式打印出来。PDF 产生最高质量的输出。但是,用户要跳越多,所以经验法则是:
nsayer提到有一个打印按钮可以改变你的屏幕布局,然后启动一个window.print()
这是一个可能会被很多人忽视的解决方案,当您认为您的用户想要更多的所见即所得时应该考虑这种解决方案。它可能应该是一个“打印机友好”的链接,尽管它会改变您的工作表的媒体类型,而不是“打印这个”。
使用 jquery,您可以执行以下操作(未选中):
$(document).ready(function(){
$("#printFriendly").click(function(){
$(link[rel=link][media=screen]).remove();
$(link[rel=link][media=print]).attr("media","screen");
});
});
你可以用 CSS 做的任何事情都可以在打印样式表中做。这意味着您可以隐藏屏幕版本中显示的打印版本中的内容,或者隐藏您希望在打印时显示的屏幕版本中的内容。您只需将 display:none 应用于相应样式表中的相应部分。
此外,为打印版本调整文本大小也是一个好主意(这对于屏幕版本来说是个坏主意 - 在这里坚持像素、ems 或百分比)。由于像素到点的映射会因不同的分辨率设备而异,所以对于打印点大小的位置存在普遍共识。