jsPDF导出PDF宽大于高异常处理

 更新时间:2023年08月25日 10:14:34   作者:DiracKeeko  
这篇文章主要为大家介绍了jsPDF导出PDF宽大于高异常处理,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪

情况说明

在将HTML内容区导出PDF时,按width和height的相对大小可以分为瘦长区域(下图蓝框)和扁宽区域(下图红框)两种情况。

我写的pdf导出逻辑在导出瘦长区域时没问题,在导出扁宽区域时,会出现PDF内容横向被截断的情况(横向展示不全)。

举例如下面两张图片。

问题所在

html导出pdf经过了2个步骤:

1.html -> img (没问题)

2.img -> pdf (出了问题)

将img转为pdf并导出用的是jsPDF。

jsPDF使用时分为3个步骤:

1.const pdf = new jsPDF(args); 创建一个指定尺寸的空白的PDF,把它想象成画布。

2.pdf.addImage(args); args有一系列的参数,在画布的指定位置放入图片。

3.pdf.save(fileName); 导出pdf。

问题出在第1步,创建空白的pdf画布。

new jsPDF(options) 官方文档 

https://artskydj.github.io/jsPDF/docs/jsPDF.html

关注format,官方文档里写了支持array,形如[595.28, 841.89] (问题就在这)

const pdf = new jsPDF("", "pt", pageSizeArr);

若 我们想要一个宽1000,高500的画布

很自然的想到pageSizeArr = [1000, 500]

但这样的输入,JSPDF会生成一个 宽500 高1000的画布

也就是说

pageSizeArr = [1000, 500]
或 pageSizeArr = [500, 1000]

jsPDF会都生成 宽500 高1000的画布 (!!!!!!!!)

在项目中,我的pageSizeArr设置如下

pageSizeArr = [scrollWidth, scrollHeight];

这种情况下,如果真的需要导出一个扁宽的HTML 内容区, (scrollWidth > scrollHeight)

画布的尺寸和HTML的内容区尺寸对不上, HTML的右侧会被截断。

解决方案

scrollWidth > scrollHeight的时候,做一个A4纸比例的画布 宽:高 = 1 : 1.414 (简化为1 : 1.4)

且 宽度 等于 scrollWidth。

pageSizeArr = [scrollWidth, 1.4 * scrollWidth];

以上就是jsPDF导出PDF宽大于高异常处理的详细内容,更多关于js导出PDF宽高异常处理的资料请关注脚本之家其它相关文章!

相关文章

  • 在HTML中使用JavaScript的两种方法

    在HTML中使用JavaScript的两种方法

    这篇文章主要介绍了在HTML中使用JavaScript的两种方法,帮助大家更好的理解和制作网页,感兴趣的朋友可以了解下
    2020-12-12
  • 你可能不知道的typescript实用小技巧

    你可能不知道的typescript实用小技巧

    作为前端程序员,TS已经成为一项必不可少的技能,本文旨在介绍 TS中的一些实用技巧,提高大家对这门语言更深的认知,这篇文章主要给大家介绍了关于typescript实用小技巧的相关资料,需要的朋友可以参考下
    2021-08-08
  • js实现简易计算器小功能

    js实现简易计算器小功能

    这篇文章主要为大家详细介绍了js实现简易计算器小功能,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2020-11-11
  • 微信小程序实现选项卡效果

    微信小程序实现选项卡效果

    这篇文章主要介绍了微信小程序实现选项卡效果,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-11-11
  • 监控微信小程序中的慢HTTP请求过程详解

    监控微信小程序中的慢HTTP请求过程详解

    这篇文章主要介绍了监控微信小程序中的慢HTTP请求过程详解,Fundebug 的微信小程序监控插件在 0.5.0 版本已经支持监控 HTTP 请求错误,在小程序中通过wx.request发起 HTTP 请求,如果请求失败,会被捕获并上报,需要的朋友可以参考下
    2019-07-07
  • js获得参数的getParameter使用示例

    js获得参数的getParameter使用示例

    这篇文章主要介绍了js获得参数的getParameter使用示例,需要的朋友可以参考下
    2014-02-02
  • 一步一步封装自己的HtmlHelper组件BootstrapHelper(二)

    一步一步封装自己的HtmlHelper组件BootstrapHelper(二)

    一步一步封装自己的HtmlHelper组件:BootstrapHelper,系列文章第二篇,感兴趣的小伙伴们可以参考一下
    2016-09-09
  • js 纯数字不重复排列的另类方法

    js 纯数字不重复排列的另类方法

    有一组数据,大概10万个左右,每一单位的值不会大于30000,要求按照由大到小的顺序不重复输出。
    2010-07-07
  • js实现带箭头的进度流程

    js实现带箭头的进度流程

    这篇文章为大家详细主要介绍了js实现带箭头的进度流程,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2020-03-03
  • SWFObject Flash js调用类

    SWFObject Flash js调用类

    一直想为 SWFObject 这个JS的类库写一个推荐帖,因为他轻便,同时功能强大,为我们的开发带来了很大的便捷。
    2008-07-07

最新评论