为什么使用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(); // 可选:打印后自动关闭
  };
};

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

相关推荐
超哥--3 小时前
B站视频内容智能分析系统(九):React 前端与管理面板
前端·react.js·前端框架
Cutecat_5 小时前
视频字幕处理工具横向:提取模式 vs 编辑模式,该如何选择
android·前端·ios·语音识别
dsyyyyy11016 小时前
JavaScript变量
开发语言·javascript·ecmascript
qq_422152576 小时前
PDF 加水印工具怎么选?2026 年文档版权保护方案对比
前端·pdf·github
kyriewen6 小时前
手写 Promise.all、race、any:不到 30 行代码,解决并发异步的所有姿势
前端·javascript·面试
brucelee1867 小时前
OpenClaw 浏览器控制(Chrome MCP)完整教程
前端·chrome
ct9787 小时前
React 状态管理方案深度对比
开发语言·前端·react
胡志辉的博客7 小时前
深入浅出理解浏览器事件循环:从一道输出题讲到 Chrome 源码
前端·javascript·chrome·chromium·event loop
代码不加糖8 小时前
js中不会冒泡的事件有哪些?
前端·javascript·vue.js
懂懂tty8 小时前
Vue2与Vue3之间API差异
前端·javascript·vue.js