

新闻资讯
技术学院门面模式解决复杂子系统调用耦合问题,通过统一入口封装多类协作流程;需依赖注入、动词命名、仅编排不封装逻辑;适用于跨域协作频繁场景,单类或无关联模块不应滥用。
门面模式不是“语法糖”,也不是 Laravel 专属的魔法,它就是一个专门给复杂子系统装上统一操作按钮的设计套路——你不用知道后台调了几个类、连了几个数据库、发了几条消息,只
要对 OrderFacade::place() 按一下,事情就办妥了。
当你的 PHP 项目里出现这类信号,就该考虑加个门面了:
User、Cart、Inventory、Payment、Notification 五个类再串起来调用Mockery::mock(InventoryService::class) 都快写成一行诗了Payment 类,发现 OrderController 里还藏着三处直接调用门面不改变子系统本身,只在它们前面立一块操作面板——把分散的入口收拢,把耦合的依赖隔离。
别照抄示例里的空壳 Facade 类,真实项目中容易踩这些坑:
public function __construct(InventoryService $inventory, PaymentGateway $payment)
placeOrder(),别用 doIt() 或 handle();返回值尽量统一(如总返回 OrderResult 对象),别一半 return true、一半 throw Exception
class OrderFacade
{
public function __construct(
private InventoryService $inventory,
private PaymentGateway $payment,
private NotificationService $notify
) {}
public function placeOrder(array $data): OrderResult
{
$order = $this->inventory->reserve($data['items']);
$payment = $this->payment->charge($order->total);
$this->notify->sendSuccess($order->id);
return new OrderResult($order->id, $payment->ref);
}
}
门面不是万能胶,滥用反而添乱:
ConfigReader::get('db.host') —— 直接用,加门面纯属套娃SystemFacade::logAndCache(),违背“单一职责”真正值得门面化的,是那些跨域协作频繁、变更频率不一、且外部调用点分散的场景,比如订单履约链路、用户生命周期管理、第三方对接聚合层。
门面真正的价值不在“写出来”,而在“谁都不再需要绕过它”——一旦所有控制器、命令、事件监听器都只认 OrderFacade,你就拿到了重构自由度的第一把钥匙。