在上一篇文章中,介绍了如何在代码架构之初,为了以后的扩展方便做的考虑,那么在现实中大部分的情况不是如此,那么我们需要重构这块么?不一定,今天我们使用另一种方式来实现装饰器。
假设现在我们处在产品的第二个阶段,有下面第一阶段代码来实现需求
class User{ function loadData(){ $res = 'load ...' . PHP_EOL; return $res; } }
还是同样的,怎么在不改变调用逻辑 和 User::loadData 的基础上来扩展呢。php给我们提供了一个方案:Trait
//首先,我们先实现一个trait trait Count{ function loadData(){ $res = parent::loadData(); //count 的逻辑 return $res; } } //接下来,把User类更名为UserBase class UserBase { function loadData(){ echo 'load ...' . PHP_EOL; } } //紧接着,重新写一个User类来继承 UserBase(如果不这样做,代码使用者估计打死你的),并且使用 Count class User extends UserBase{ use Count; }
这样,我们就完成装饰器的功能,甚至能在不改变原来代码的情况下偷梁换柱做一些更加彻底的操作。