html转换为pdf问题及其解决方案

标签: Html 分类: 后台服务 创建时间:2019-02-14 00:56:00 更新时间:2024-11-15 10:49:44

通过word模板转为pdf,经历过很多的技术探索。刚开始使用的是jacob这个插件,缺点是需要安装office,而且每次打开关闭word都很慢。后来改为使用itext+flyingsaucer,itext不支持css,flyingsaucer支持css2.1,使用起来也是特别不顺手,生成的pdf虽然快速,但是样式也是不尽如人意。最后,几经周折,选择了wkhtmltopdf这样一个跨平台的命令行工具,加上freemarker模板引擎,就可以实现从数据库获取数据填充模板,最终生成pdf和word格式的文件了,效率和最终生成的样式,都还算比较令人满意,主要的缺点就是需要再服务器上安装wkhtmltopdf这样一个程序,然后需要设置环境变量,使其能在多个目录下使用。下面主要介绍使用wkhtmltopdf中的坑。

1、”&nbsp”占半个汉字字符的问题。
这个问题也是听奇葩的,按正常的html解析来看 它叫不换行空格,全称No-Break Space,它是最常见和我们使用最多的空格,大多数的人可能只接触了&nbsp,它是按下space键产生的空格。在HTML中,如果你用空格键产生此空格,空格是不会累加的(只算1个)。要使用html实体表示才可累加,该空格占据宽度受字体影响明显而强烈。经测试在宋体的情况下,&nbsp只占半个字符的宽度。所以有时候通过word生成的html中存在&nbsp时,生成的pdf会有错位的情况,这种情况,只需将一个&nbsp,换成两个&nbsp就可以了。

2、通过word生成html注意事项
通过word另存为html的时候,在另存为对话框中,应选择筛选过的网页,并且注意在工具->web选项->编码->utf-8,生成的html也不宜立即使用,应使用浏览器器重新打开html,查看样式,一般不尽如人意,此时可以通过右键单击html,选择通过word打开,重新调整格式,再次另存为筛选过的网页,基本上就可以满足需求了。

小额赞助
本人提供免费与付费咨询服务,感谢您的支持!赞助请发邮件通知,方便公布您的善意!
**光 3.01 元
Sun 3.00 元
bibichuan 3.00 元
微信公众号
广告位
诚心邀请广大金主爸爸洽谈合作
每日一省
isNaN 和 Number.isNaN 函数的区别?

1.函数 isNaN 接收参数后,会尝试将这个参数转换为数值,任何不能被转换为数值的的值都会返回 true,因此非数字值传入也会返回 true ,会影响 NaN 的判断。

2.函数 Number.isNaN 会首先判断传入参数是否为数字,如果是数字再继续判断是否为 NaN ,不会进行数据类型的转换,这种方法对于 NaN 的判断更为准确。

每日二省
为什么0.1+0.2 ! == 0.3,如何让其相等?

一个直接的解决方法就是设置一个误差范围,通常称为“机器精度”。对JavaScript来说,这个值通常为2-52,在ES6中,提供了Number.EPSILON属性,而它的值就是2-52,只要判断0.1+0.2-0.3是否小于Number.EPSILON,如果小于,就可以判断为0.1+0.2 ===0.3。

每日三省
== 操作符的强制类型转换规则?

1.首先会判断两者类型是否**相同,**相同的话就比较两者的大小。

2.类型不相同的话,就会进行类型转换。

3.会先判断是否在对比 null 和 undefined,是的话就会返回 true。

4.判断两者类型是否为 string 和 number,是的话就会将字符串转换为 number。

5.判断其中一方是否为 boolean,是的话就会把 boolean 转为 number 再进行判断。

6.判断其中一方是否为 object 且另一方为 string、number 或者 symbol,是的话就会把 object 转为原始类型再进行判断。

每日英语
Happiness is time precipitation, smile is the lonely sad.
幸福是年华的沉淀,微笑是寂寞的悲伤。