保存网页为PDF

通过浏览器 F12 开发者工具的控制台(Console)执行 JavaScript 代码,直接将当前打开的网页保存为 PDF

  • 打开目标网页并等待加载完成
  • 按 F12 打开开发者工具 → 切换到 Console(控制台)标签
  • 复制粘贴以下代码并回车执行
javascript 复制代码
(function exportPageToPDF() {
    // 1. 创建打印设置的辅助函数(优化PDF导出效果)
    function optimizePrintSettings() {
        // 创建临时样式,优化PDF打印效果(去除页眉页脚、保留背景、调整边距)
        const style = document.createElement('style');
        style.id = 'pdf-export-style';
        style.textContent = `
            @media print {
                /* 移除浏览器默认的页眉页脚 */
                @page {
                    margin: 10mm; /* 设置PDF页边距(10毫米),可自行调整 */
                }
                /* 强制保留背景色和图片 */
                body {
                    -webkit-print-color-adjust: exact !important;
                    print-color-adjust: exact !important;
                    background: white !important;
                }
                /* 隐藏可能干扰的元素(可根据网页自定义) */
                header, footer, .ad-banner {
                    display: none !important;
                }
            }
        `;
        document.head.appendChild(style);
        
        // 2. 触发打印(用户需手动选择"另存为PDF")
        window.print();
        
        // 3. 打印后移除临时样式(避免影响网页正常显示)
        setTimeout(() => {
            document.head.removeChild(style);
        }, 1000);
    }

    // 执行主逻辑
    try {
        optimizePrintSettings();
        console.log('✅ PDF导出流程已触发,请在打印窗口选择"另存为PDF"');
    } catch (error) {
        console.error('❌ 导出失败:', error.message);
    }
})();
相关推荐
humcomm29 分钟前
元框架的工作原理详解
前端·前端框架
canonical_entropy37 分钟前
Attractor Before Harness: AI 大规模开发的方法论
前端·aigc·ai编程
zhangxingchao1 小时前
多 Agent 架构到底怎么选?从 Claude Agent Teams、Cognition/Devin 到工程落地原则
前端·人工智能·后端
IT_陈寒1 小时前
SpringBoot那个自动配置的坑,害我排查到凌晨三点
前端·人工智能·后端
Honor丶Onlyou1 小时前
VS Code 右键菜单修复记录
前端
卡卡军1 小时前
agmd 1.0 重磅升级——Rust 重写,性能起飞
javascript·rust
PILIPALAPENG1 小时前
Python 语法速成指南:前端开发者视角(JS 类比版)
前端·人工智能·python
Larcher1 小时前
🔥 告别抓瞎:用 Claude Code (cc) 优雅接手与维护已有项目
javascript·机器学习·前端框架
JYeontu1 小时前
轮播图不够惊艳?试下这个立体卡片轮播图
前端·javascript·css
张就是我1065921 小时前
从前端角度理解 CVE-2026-31431
前端