在纯web的前提下(不考虑移动端native),PDF的功能基本包括:
- 客户端PDF:最简单的场景,实现方式也很多,基本不需要有什么顾虑的地方,简单的实现可以参考系列第一篇文章。
- 客户端PDF预览:需要考虑html模板、css样式在正常页面与预览页面的共用问题,一样的东西写两套,那么维护起来工作量也会更大,更容易产生顾此失彼的问题,导致bug。可以参考系列第二篇文章。
- 服务端PDF:优点在于数据量大的时候不需要考虑网络传输的问题,也可以屏蔽掉系统不同带来的PDF渲染差异问题。同理,需要考虑是不是需要支持预览,html模板,css样式、数据源逻辑与绑定,需要考虑在正常页面、预览页面和服务端渲染页面之间共享。可以参考系列第三、第四篇文章。
- 定时PDF任务:这个需求由于比较小众,在前面的系列文章没有提及,它和服务端生成PDF其实没有本质区别,唯一需要考虑的就是权限问题。当用户从客户端发起PDF生成任务时,发送到服务端生成PDF,这时是带有当前登录用户的用户信息的。但是,当这个任务是定时任务时,是没有用户信息的。需要一个特殊的定时任务用户来负责生成PDF文件。