主要的思想是利用call_user_func_array()和容器結合使用的。php
容器用的上一篇寫的容器鏈接以下segmentfault
連接描述測試
核心代碼,理解都在註釋中this
<?php //reqeuestFacade.php namespace facade{ class Request extends Facade{ public function getFacadeName(){ return 'request'; } } } ?> <?php //facade.php namespace facade{ class Facade{ public static function createFacade(){ $class = static::class; //在這個獲取的$class實際上是facade\reqeust //在這裏利用static::獲得getFacadeName,返回真正的request的變量名 $facadeClass = static::getFacadeName(); if ($facadeClass) { $class = $facadeClass; } elseif (isset(self::$bind[$class])) { $class = self::$bind[$class]; } //echo $class; 利用容器去獲取reqeust,而不是facade\reqeust return \Container::get($class); } public static function __callStatic($method, $params) { return call_user_func_array([static::createFacade(), $method], $params); } } } ?>
下面測試代碼
reqeust.phpspa
<?php class Request{ public $name = 'Real Request'; public function sayName(){ echo $this->name; } } ?>
test.phpcode
<?php use facade\Request; include "Container.php"; include "Facade.php"; include "RequestFacade.php"; include "Request.php"; Request::sayName(); ?>
最後的結果圖片