這篇文章主要給大家介紹了關於Laravel中服務提供者和門面模式使用的相關資料,文中透過詳細的範例程式碼向大家介紹了Laravel中的服務提供者和門面模式,對大家的學習或者工作有一定的參考學習價值,需要的朋友們一起學習學習吧。
前言
在laravel中,當我們可能需要用到自己添加的類別時,可以建立一個資料夾專門存放類別文件,也可以使用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 門面模式
先看下簡介: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'; } }
以上是簡單介紹Laravel中服務提供者與門面模式的詳細內容。更多資訊請關注PHP中文網其他相關文章!