为什么使用window.print打印的页面只有第一页。其他页面没有了。并且我希望打印的是一个弹窗的内容,竟然把弹窗的样式边框和打印的按钮都打印进去了

可以单独的设置打印的样式、

复制代码
@media print {
  @page {
    size: A4;//默认A4的纸张
    margin: 10mm; /* 上下左右 10mm */
  }
  body {
    height: auto !important; //不设置高度。避免只有一页
    padding: 0 !important;
    margin: 0 !important;
    overflow: auto !important;
    font-size: 10px !important;
    line-height: 1.2 !important;
  }
.print-no{
   display:none;//在打印的时候不显示
 }
}

但是发现设置了之后不起作用。或许是你放在style的scoped里面了。拿出来试试。


如果想使用插件推荐使用

复制代码
vue3-print-nb

如果你不想使用插件,推荐做法:使用独立的打印容器 + 全局打印样式隐藏非打印内容。

复制代码
const handlePrint = () => {
  const printContent = document.querySelector('.print-container').cloneNode(true); //print-container是你要打印的html的class标签

  // 创建一个干净的打印窗口容器
  const printWindow = window.open('', '_blank');
  printWindow.document.write(`
    <!DOCTYPE html>
    <html>
      <head>
        <title>打印</title>
        <style>
          body {
            font-family: SimSun, "宋体", serif;
            font-size: 12pt;
            line-height: 1.3;
            margin: 0;
            padding: 10mm;
            background: #fff !important;
          }
          /* 这里可以内联你原有的打印样式 */
          .print-table { width: 100%; border-collapse: collapse; }
          .print-table td { border: 0.5pt solid #000; padding: 4pt 6pt; }
  
          /* 其他必要样式... */
        </style>
      </head>
      <body>
        ${printContent.outerHTML}
      </body>
    </html>
  `);
  printWindow.document.close();
  printWindow.focus();

  // 等待加载完成再打印(可选)
  printWindow.onload = () => {
    printWindow.print();
    printWindow.close(); // 可选:打印后自动关闭
  };
};

✅ 优点:完全脱离当前页面上下文,不会受弹窗、遮罩、全局样式干扰。还可以单独的设置样式。

相关推荐
Jackson__26 分钟前
分享一个横向滚动案例,带悬停暂停,通用性很强
前端
MariaH1 小时前
git rebase的使用
前端
_柳青杨1 小时前
深入理解 JavaScript 事件循环
前端·javascript
阡陌Jony1 小时前
关于前端性能优化的一些问题:
前端
用户600071819102 小时前
【翻译】简化 TSRX
前端
IT乐手3 小时前
佛德角逼平西班牙,国足还有啥借口?
前端
JustHappy3 小时前
我汇总了身边朋友的经历才发现,其实第一份实习是最难找的......
前端·后端·面试
星栈4 小时前
Dioxus 的响应式系统:`Signal`、`Memo`、`Effect` 和异步状态到底该怎么分工
前端·前端框架
yingyima4 小时前
Java 正则表达式:比你想象的更强大
前端
yuanyxh6 小时前
macOS 应用 - 纯对话生成
前端·macos·ai编程