chrome浏览器web打印需要了解的几个小技巧

chrome浏览器web打印需要了解的几个小技巧

月光魔力鸭

2018-09-20 11:21 阅读 4171 喜欢 4 web打印 chrome打印

当我们使用web打印相关的解决方案的时候,还有不少小坑值得注意下,同时需要了解几个小技巧提升在web打印上的友好度,以下整理一些常见的小技巧。

Tip1 - 应用媒体查询

网页中屏幕展示的样式在打印的时候可能不太一样,有些需要隐藏或者需要调整,包括是否展示、字体大小、颜色等等,那么我们可以通过使用媒体查询来控制打印样式。

//media = screen 为屏幕显示的样式
<link rel="stylesheet" href="css/mainstylesheet.css" media="screen" />
//media = print 为需要打印的时候使用的样式
<link rel="stylesheet" href="css/printstylesheet.css" media="print" />

这样,我们可以把在打印的时候需要调整的样式放在printstylesheet文件中。当然如果不想通过文件来判断都写在一起也是可以的,通过如下media print 来指定某些在print下的样式表现。

@media print{
    .logo{
        display:none;
    }    
}

然后,还可以通过import的方式来引入在print下的样式文件:

<style type="text/css">
      @import url("css/printstylesheet.css") print;
  </style>
Tip2 - 展示与隐藏

页面中有些元素可能在屏幕中需要展示,但是在打印的时候不需要,所以需要将这些隐藏掉,那么只需要将这些元素设置为display:none即可,如下:

div{display:none;}/**当然这种样式还是需要放在media print 中了。**/
Tip3 - 分页符

在打印的时候,如果内容过多,是不会自动进行分页的,如果你认为该位置不合适,也可以通过样式来控制在哪个位置进行分页处理。

.break_before { page-break-before: always; }/**应用给页面顶部元素即可**/
.break_after { page-break-after: always; }/**应用页面底部元素即可**/

通过分页符号来控制分页位置。当然page-break-before page-break-after不只有always一个值,还有其他的几个值可以使用。

描述
auto 默认值,如果必要则在元素前插入分页符
always 在元素前/后插入分页符
avoid 避免在元素前/后插入分页符
left 在元素之前/后足够的分页符,一直到一张空白的左页为止
right 在元素之前/后足够的分页符,一直到一张空白的右页为止
inherit 规定应该从父元素继承 page-break-before/after 属性的设置
Tip4 - 控制打印首选项

当我们在打印的时候,如果需要打印到A3纸上或者需要横向如何办呢?当然,在web打印设置中是可以设置的,但是,我们想通过程序来设置默认项/首选项那应如何处理呢?

web打印更多设置 我们可以通过css来控制我们的首选项:

@page{
    size : A4 portrait;/*A4 portrait纵向,landscape 横向*/
    @top-left {
        display: none;
    }
    @bottom-center {
        display: none;
    }
}

关于@page的规则,可以参考文章http://www.w3cplus.com/css/designing-for-print-with-css.html ,这里讲解的很细致,我们也可以通过这些规则来设定页眉页脚内容等。

Tip5 - 打印背景色

在web中背景色在打印的时候无法显示,我们可以通过打印设置中的选项“背景图形”勾选来让背景色或背景图片来展示出来,同时,我们也可以通过css来控制是否展示。

.dot{
    position:absolute;
    -webkit-print-color-adjust: exact;/**通过该设置,可以在打印时显示背景图和背景色**/
    background-image:url(/bg.jpg); 
}

以上是chrome浏览器的设置,其他的设置我没有去查找,不过应该是都有对应的设置的。

Tip6 - 其他

以上是chrome浏览器中在web打印的时候需要了解的几个小技巧,暂时整理这些,后续发现陆续补充进来。

转载请注明出处: https://chrunlee.cn/article/chrome-web-print-tips.html


感谢支持!

赞赏支持
提交评论
评论信息 (请文明评论)
暂无评论,快来快来写想法...
推荐
通过frp做穿透实现https 访问本地http项目。
之前做了一段时间的上传相关的断点续传和秒传功能,这里整理下大体思路
本篇文章以一个实际的小项目为主题进行从头到尾的讲解实现,该项目总计开发时长约6小时,主要是有很多页面或功能都是现成的,直接复制过来的,剩下的就调整下样式、字段内容等。
最近看某站壁纸挺好看的,抓了几百张放本地...可总不能每天手动去换吧,就做了一个随机更换的小工具。
最近有系统需要知道性能瓶颈,尝试使用jmeter对重要接口进行并发测试,确定能否支撑一定的用户数量。
反爬有很多手段,字体反爬就是其中之一。之前一直都是听过,但是却没怎么在实际爬虫中遇到过,最近在一个爬虫题目网站上看到了,试了试,发现还挺麻烦,当然自己从头研究字体肯定麻烦,简单的是模块多的是,选几个就过了。
mysql数据库插入double类型确没有小数点
前几天同事抱怨说微博太费劲了... 一万多条记录,可能会把他累死,我心想.. 重复工作不都可以用程序代替么..