主要的思想是利用call_user_func_array()和容器結合使用的。
容器用的上一篇寫的容器連接如下
核心代碼,理解都在註釋中
<?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.php
<?php
class Request{
public $name = 'Real Request';
public function sayName(){
echo $this->name;
}
}
?>
test.php
<?php
use facade\Request;
include "Container.php";
include "Facade.php";
include "RequestFacade.php";
include "Request.php";
Request::sayName();
?>
最後的結果