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

被折叠的 条评论
为什么被折叠?



