您的当前位置:首页>全部文章>文章详情

CSS @media print控制浏览器web打印样式

发表于:2022-08-28 09:14:41浏览:2441次TAG: #css #print #web打印 #浏览器打印

浏览器打印,可以通过 window.print() 、document.execCommand(‘print’) 调用浏览器打印。不同浏览器的区别:在Safari和Chrome都会弹起打印预览的窗口,FireFox和 IE 没有预览而是直接让你选择打印机,但是直接使用浏览器打印虽然省事,但是存在很多问题,无法满足我们的打印需求:

1、打印的是整个网页,不能打印局部内容;
2、打印不支持自定义分页行为,默认不支持批量打印;
3、打印的时候样式有问题,所见非所得;
4、打印可以准确识别的样式单位是绝对单位(如pt、mm、cm),对相对单位识别不同打印机可能会得到意想不到的结果;

@media print里面的内容只对打印出来的内容有效,之外的内容就是屏幕显示的样式。

  @media print {}{
    .class {
      color: black;
    }
  }

打印默认是A4的尺寸,如果超过了会被隐藏,在css控制合适的缩放比例:

  html{
    zoom:56%;
  }

用于伪类修改样式
:left:right:first

通过:left:right设置左右页面不同样式,并不代表用户代理会将页面双面打印

/* 通过分别设置左页和右页不同的左右页面距,为装订边留出更多的空间 */
@page :left {
    margin-left: 2.5cm;
    margin-right: 2.7cm;
}

@page :right {
    margin-left: 2.7cm;
    margin-right: 2.5cm;
}

:first用于匹配到文档的第一页

/* 首页上页边距设置为 10cm */
@page :first {
    margin-top: 10cm; 
}

分页:page-break-before
page-break-before用于设置元素前面的分页行为

div {
   page-break-before: avoid;
}

完整样式

@media print {
    @page {
      /* 纵向打印 */
      // size: portrait;

      /* 横向打印 */
      size: landscape;

      /* 去掉页眉页脚*/
      margin-top: 0;
      margin-bottom: 0;
    }
    /* 告诉浏览器在渲染它时不要对框进行颜色或样式调整 */
    * {
      -webkit-print-color-adjust: exact !important;
      -moz-print-color-adjust: exact !important;
      -ms-print-color-adjust: exact !important;
      print-color-adjust: exact !important;
    }

    /*打印不显示打印按钮*/
    .print-button-container {
      display: none !important;
    }

    /* 伪类 :first 用于匹配到文档的第一页, 首页上页边距设置为 10cm */
    @page :first {
      margin-top: 10cm;
    }

    /* 通过分别设置左页和右页不同的左右页面距,为装订边留出更多的空间 */
    /**/
    @page :left {
      margin-left: 2.5cm;
      margin-right: 2.7cm;
    }
    @page :right {
      margin-left: 2.7cm;
      margin-right: 2.5cm;
    }