thinkphp中facade的實現

主要的思想是利用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();

?>

最後的結果
圖片描述

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章