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

简介: 当我们使用web打印相关的解决方案的时候,还有不少小坑值得注意下,同时需要了解几个小技巧提升在web打印上的友好度,以下整理一些常见的小技巧
当我们使用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 - 其他
  • 字体颜色:打印的时候,字体颜色设置为黑色。
  • 单位:屏幕展示我们一般使用px,但是打印尽量使用物理单位cm in
  • 浮动:尽量少的使用浮动,在某些浏览器上浮动可能会导致无法正常打印

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

相关文章
|
4月前
|
Web App开发 数据采集 存储
WebDriver与Chrome DevTools Protocol:如何在浏览器自动化中提升效率
本文探讨了如何利用Chrome DevTools Protocol (CDP) 与 Selenium WebDriver 提升浏览器自动化效率,结合代理IP技术高效采集微博数据。通过CDP,开发者可直接操作浏览器底层功能,如网络拦截、性能分析等,增强控制精度。示例代码展示了如何设置代理IP、cookie及user-agent来模拟真实用户行为,提高数据抓取成功率与稳定性。适用于需要频繁抓取互联网数据的应用场景。
585 3
WebDriver与Chrome DevTools Protocol:如何在浏览器自动化中提升效率
|
1天前
|
Web App开发 数据采集 JavaScript
Chrome浏览器实例的TypeScript自动化脚本
Chrome浏览器实例的TypeScript自动化脚本
|
5月前
|
Web App开发 iOS开发
Web 浏览器
【8月更文挑战第27天】Web 浏览器。
69 2
|
2月前
|
人工智能 前端开发 计算机视觉
Inpaint-Web:纯浏览器端实现的开源图像处理工具
在刷短视频时,常看到情侣在景区拍照被路人“抢镜”,男朋友用手机将路人“P”掉,既贴心又有趣。最近我发现了一个纯前端实现的开源项目——inpaint-web,可在浏览器端删除照片中的部分内容,非常酷。该项目基于 WebGPU 和 WASM 技术,支持图像修复与放大,已在 GitHub 上获得 5.1k Star。项目地址:[GitHub](https://github.com/lxfater/inpaint-web)。
73 3
 Inpaint-Web:纯浏览器端实现的开源图像处理工具
|
2月前
|
存储 缓存 前端开发
Web端IM聊天消息该不该用浏览器本地存储?一文即懂!
鉴于目前浏览器技术的进步(主要是HTML5的普及),在Web网页端IM聊天应用的技术选型阶段,很多开发者都会纠结到底该不该像原生移动端IM那样将聊天记录缓存在浏览器的本地,还是像传统Web端即时通讯那样继续存储在服务端?本文将为你简洁明了地讲清楚浏览器本地存储技术(Web Storage),然后你就知道到底该怎么选择了。
36 1
|
2月前
|
Web App开发 缓存 安全
WIN11 Chrome 双击打不开闪退及Chrome浏览器不能拖拽文件crx
【11月更文挑战第6天】本文介绍了 WIN11 系统中 Chrome 浏览器双击打不开闪退及不能拖拽文件 crx 的原因和解决方法。包括浏览器版本过旧、扩展程序冲突、硬件加速问题、缓存过多、安全软件冲突、系统文件损坏、用户配置文件损坏等问题的解决方案,以及 crx 文件的屏蔽、权限问题和文件格式问题的处理方法。
163 2
|
2月前
|
Web App开发 Linux iOS开发
Chrome浏览器如何导出所有书签并导入书签
【11月更文挑战第4天】本文介绍了如何在 Chrome 浏览器中导出和导入书签。导出时,打开书签管理器,点击“整理”按钮选择“导出书签”,保存为 HTML 文件。导入时,同样打开书签管理器,点击“整理”按钮选择“导入书签”,选择之前导出的 HTML 文件即可。其他主流浏览器也支持导入这种格式的书签文件。
788 2
|
2月前
|
Web App开发 JavaScript 前端开发
使用 Chrome 浏览器的内存分析工具来检测 JavaScript 中的内存泄漏
【10月更文挑战第25天】利用 Chrome 浏览器的内存分析工具,可以较为准确地检测 JavaScript 中的内存泄漏问题,并帮助我们找出潜在的泄漏点,以便采取相应的解决措施。
353 9
|
3月前
|
Web App开发 开发者
|
3月前
|
Web App开发 JSON 安全
Chrome浏览器的跨域问题
【10月更文挑战第6天】