Angular 与 PDF之五 实现方式的选择与扩展

Angular 与 PDF之五 实现方式的选择与扩展_第1张图片

 在纯web的前提下(不考虑移动端native),PDF的功能基本包括:

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

当然,需求是不断变化的,当PDF的需求从简单变复杂的这个过程,也是一个很好的代码重构和反思的过程,家家有本难念的经,在代码实现也是同理。希望这个系列可以帮助大家更好的设计功能,少走弯路。

你可能感兴趣的:(Angular,angular)