一、需求说明

  学校 OA 系统的采购审批项目:需求是:

  采购员采购教学器材:

  1、如果金额 小于等于 5000,由教学主任审批(0 <= x <= 5000)

  2、如果金额 小于等于 10000,由院长审批(5000 <= x <= 10000)

  3、如果金额 小于等于 30000,由副校长审批(10000 <= x <= 30000)

  4、如果金额 超过 30000,由学校审批(30000 <= x )

 

二、传统方式解决 OA 系统审批,传统的设计方案

  

 

   我们可以创建一个 PurchaseRequest 请求类,然后根据其中的金额通过 if...else 来判断需要交给谁进行审批。

 

三、传统方案解决 OA 系统审批问题分析

  1、传统方式是:接收到一个采购请求后,根据采购金额来调用对应的 Approver(审批人)来完成审批;

  2、传统方式的问题分析:

    客户端这里会使用到分支判断(比如 switch)来对不同的采购请求处理,这样就存在如下问题:

    (1)如果各个级别的人员审批金额发生变化,在客户端也需要变化;

    (2)客户端必须明确的知道有多个人审批级别和访问;

  3、这样对一个采购请求进行处理 和 Approver(审批人)就存在强耦合关系,不利于代码的扩展和维护。

 

posted on 2021-03-06 10:58  格物致知_Tony  阅读(51)  评论(0编辑  收藏  举报