其他 | 把 csdn 博客的内容导出成 pdf 文件

背景 :使用 edge浏览器 打印博客资料,出现内容被遮盖、纸张形状奇怪 等问题;换成谷歌浏览器打印同样出现该问题。

尝试:参考文章,在此基础上进行改进,满足可以✔保留内容不遮盖(使内容不会超出页面的边界)、✔修改页边距的、✔保留A4纸张大小,还✔保留代码的高亮。

解决 :谷歌浏览器中 F12 -》控制台输入: "允许粘贴"或"allow pasting" 后 回车 -》以下输入代码(可以直接选择以下 2.改进后的代码)-》跳出打印界面

1. 原始参考代码:

javascript 复制代码
(function doPrint(){      
	'use strict';
	var articleBox = $("div.article_content");
	articleBox.removeAttr("style");
	var head_str = "";       
	var foot_str = "";   
	var older = document.body.innerHTML;       
	var title= document.getElementsByClassName('article-title-box')[0].innerHTML; 
	var main_body = document.getElementsByClassName('article_content')[0].innerHTML;
	document.body.innerHTML = head_str + title + main_body + foot_str;
	$("#mainBox").width("100%");
	document.getElementsByTagName('body')[0].style.zoom=0.8;     
	window.print();
	document.body.innerHTML = older;
	return false;
})();

2. 改进后的代码:

javascript 复制代码
(function doPrint(){       
    'use strict';
    var articleBox = $("div.article_content");
    articleBox.removeAttr("style");

    var older = document.body.innerHTML;       
    var title = document.getElementsByClassName('article-title-box')[0].innerHTML; 
    var main_body = document.getElementsByClassName('article_content')[0].innerHTML;

    // 收集当前页面的所有 <link rel="stylesheet"> 和 <style>
    var styles = "";
    document.querySelectorAll("link[rel='stylesheet'], style").forEach(function(node){
        styles += node.outerHTML;
    });

    // 打印专用样式,保留A4大小
    var printStyles = `
      <style>
        @page {
          size: A4;         /* 指定纸张大小为 A4 */
          margin: 15mm;     /* 页边距可调 */
        }
        body {
          zoom: 0.9;        /* 页面整体缩放 */
        }
        pre, code {
          white-space: pre-wrap !important; 
        }
      </style>
    `;

    var head_str = "<head>" + styles + printStyles + "</head><body>";
    var foot_str = "</body>";

    document.body.innerHTML = head_str + title + main_body + foot_str;

    window.print();

    document.body.innerHTML = older;
    return false;
})();

参考:如何将CSDN文章导出为pdf文件(清爽) - 知乎

ps:书籍的页边距2.5cm,一般打印页边距1.5-2cm。

相关推荐
小咖自动剪辑11 小时前
Base64与图片互转工具增强版:一键编码/解码,支持多格式
人工智能·pdf·word·媒体
开开心心_Every18 小时前
家常菜谱软件推荐:分类齐全无广告步骤详细
linux·运维·服务器·华为od·edge·pdf·华为云
开开心心就好18 小时前
键盘映射工具改键位,绿色版设置后重启生效
网络·windows·tcp/ip·pdf·计算机外设·电脑·excel
cuber膜拜19 小时前
Marp CLI快速入门
pdf·npm·markdown·ppt·marp
reasonsummer19 小时前
【办公类-53-09】20260131Python模仿制作2025学年第二学期校历(excel+pdf)
python·pdf
心语星光20 小时前
用python语言的pyautogui库实现伪批量将xdf文件打印为pdf文件
开发语言·python·pdf·自动化
iReachers20 小时前
PDF一机一码加密大师1.1.0更新至2026最新版, 强力加密PDF, 无需额外安装阅读器, 附CSDN下载地址
pdf
web打印社区2 天前
前端开发实现PDF打印需求:从基础方案到专业解决方案
前端·vue.js·react.js·electron·pdf
Kratzdisteln2 天前
【MCM】(x= (N_A),y=(N_G),z=(p))RGB=T*
pdf
Kratzdisteln2 天前
【1902】process_assignment_pdf()
大数据·人工智能·pdf