首頁 >php框架 >Laravel >laravel門面與服務提供者區別

laravel門面與服務提供者區別

藏色散人
藏色散人原創
2019-08-06 11:16:042623瀏覽

laravel門面與服務提供者區別

laravel門面模式與服務提供者差異

以Laravel 自帶的檔案系統為例,在config /app.php 的設定檔的providers 陣列中,註冊了一個服務提供者:

Illuminate\Filesystem\FilesystemServiceProvider::class,

在alias 陣列中定義了一個門面:

‘File’ => Illuminate\Support\Facades\File::class,

透過這兩個步驟,我們就可以非常方便的使用Laravel 提供的檔案系統相關的操作,而且呼叫形式很簡潔,如:

File::exist ($path),判断文件是否存在。
File::get ($path, $lock = false),获取一个文件的内容。
File::append ($path, $data),把内容追加到一个文件末尾。
File::files ($directory),获取一个目录下所有文件。

那麼這是如何做到的呢?以下分別講一講 Laravel 的服務提供者和門面模式。

服務提供者

先看看定義:

服務提供者是所有 Laravel 應用程式啟動的中心所在。包括你自己的應用程序,以及所有的 Laravel 核心服務,都是透過服務提供者啟動的。

在檔案系統這個服務提供者中,位置 /vendor/laravel/framework/src/Illuminate/Filesystem/FilesystemServiceProvider.php,register 方法可以看到綁定了一個單例:

protected function registerNativeFilesystem()
{
    $this->app->singleton('files', function () {
        return new Filesystem;
    });
}

這個單例是Filesystem 這個類別的單例模式。當然,這個服務提供者中也可以綁定其他的單例,或做更多的事情。我們這裡只研究 File::exist () 這種呼叫方式的原理。

那麼這樣一來就有個 files 的單例,其實就是 Filesystem 這個類別的實例。

此時,如果沒有Facade,也是可以呼叫到Filesystem 這個實例的方法的,那就是這樣呼叫:

app(‘files’)->exist($path)

好了,現在開始講Facade.

Facade 門面模式

先看下簡介:

Facades /fəˈsäd/ 為應用程式的服務容器中可用的類別提供了一個「靜態」介面。 Laravel 自帶了許多的 facades,可以用來訪問其幾乎所有的服務。 Laravel facades 是服務容器裡那些基類的「靜態代理」,相比於傳統的靜態方法調用,facades 在提供更簡潔且豐富的語法的同時,還有更好的可測試性和擴展性。

本文一開始講到alias 陣列定義了一個File,具體的類別是

Illuminate\Support\Facades\File::class,

它的內容是:

class File extends Facade
{
    /**
     * Get the registered name of the component.
     *
     * @return string
     */
    protected static function getFacadeAccessor()
    {
        return 'files';
    }
}

它實際上回傳了一個名稱,注意這個名稱files,不就是剛剛綁定的單例模式的名稱嗎?沒錯。

這樣一來,就可以使用 File 這個別名或說門面,來呼叫這個 Filesystem 實例中的方法了。

透過本文,希望大家能夠了解服務提供者,Facade,和實際呼叫的類別的實例之間的關係。

更多Laravel相關技術文章,請造訪Laravel框架入門教學專欄進行學習!

以上是laravel門面與服務提供者區別的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn