最近在學習laravel,正好學習到了ioc容器,但發現網上這方面的資料較少,所以將自己學習的總結下,下面這篇文章主要給大家介紹了關於Laravel學習教程之IOC容器的相關資料,需要的朋友可以參考借鑒,下面來一起看看吧。
前言
Laravel使用IoC(Inversion of Control,控制倒轉,這是設計模式,可以先查看下百科)容器這個強而有力的工具管理類依賴。依賴注入(也是一種設計模式,一般用於實現IoC)是一個不用編寫固定程式碼來處理類別之間依賴的方法,相反的,這些依賴是在運行時注入的,這樣允許處理依賴時具有更大的靈活性。
理解 Laravel IoC容器是建立強大應用程式所必要的,也有助於Laravel 核心本身。下面話不多說了,來一起看看詳細的介紹吧。
基本用例
綁定一個類型到容器
IoC 容器有兩種方法來解決依賴關係:透過閉包回調或自動解析。首先,我們來探究一下閉包回調。首先,需要綁定一個「類型」到容器中:
App::bind('foo', function($app) { return new FooBar; });
從容器中取得一個類型
$value = App::make('foo');
當執行App::make
方法,閉包函數被執行並傳回結果。
綁定一個」共用「類型到容器
有時,你只想將綁定到容器的類型處理一次,然後接下來從容器中取得的都應該是相同實例:
App::singleton('foo', function() { return new FooBar; });
綁定一個已經存在的類型實例到容器
你也可以使用instance方法,將一個已經存在的物件介面綁定到容器中:
$foo = new Foo; App::instance('foo', $foo);
##哪裡去註冊綁定呢
IoC綁定,很像事件句柄或路由過濾,通常在"bootstrap code(引導碼)"之後完成。換句話說,它們在你的應用程式準備處理請求,也即是在一個路由或控制器被實際執行之前執行。和其他引導程式碼一樣,start檔案通常會作為IoC綁定註冊一種方法。另外,你可以建立一個app/ioc.php(文件名不一定一樣)文件,並在start文件中包含它。 如果你的應用程式有很大量IoC綁定,或者你想根據不同的分類將IoC綁定分割到不同的文件,你可以嘗試在服務提供者(見下面)中進行綁定自動解析
取得一個類別
IoC容器夠強大,在許多場景下不需要任何配置就能取得類別。例如class FooBar { public function __construct(Baz $baz) { $this->baz = $baz; } } $fooBar = App::make('FooBar');
注意:#我們雖然沒有在容器中註冊FooBar類,容器仍然可以取得該類,甚至自動注入Baz依賴!
當某個型別沒有綁定到容器,IoC容器會使用 PHP 的反射工具來檢查類別和讀取建構器的類型提示。使用這些信息,容器可以自動建構類別實例。綁定一個介面實作
然而,在某些情況下,一個類別可能依賴某個介面實現,而不是一個 「特定的類別」。當在這種情況下,App::bind方法必須通知容器注入哪個介面實作:
#
App::bind('UserRepositoryInterface', 'DbUserRepository');
class UserController extends BaseController { public function __construct(UserRepositoryInterface $users) { $this->users = $users; } }
實際用例
Laravel 提供了幾個方法來使用 IoC 容器增強應用程式可擴充性和可測試性。一個主要的例子是取得控制器。所有控制器都透過 IoC 容器取得,意味著可以在控制器建構方法中對依賴的類型提示,它們將自動被注入。對控制器的依賴關係做類型提示
class OrderController extends BaseController { public function __construct(OrderRepository $orders) { $this->orders = $orders; } public function getIndex() { $all = $this->orders->all(); return View::make('orders', compact('all')); } }
IoC 所使用的其他範例
篩選器, composers, 和 事件句柄也能夠從IoC容器中取得。當註冊它們的時候,只需要把它們使用的類別名稱簡單給出即可:Route::filter('foo', 'FooFilter'); View::composer('foo', 'FooComposer'); Event::listen('foo', 'FooHandler');
服務提供者 #
服务器提供器是将一组相关 IoC 注册到单一路径的有效方法。将它们看做是一种引导组件的方法。在服务器提供器里,你可以注册自定义的验证驱动器,使用 IoC 容器注册应用程序仓库类,甚至是自定义 Artisan 命令。
事实上,大多数核心 Laravel 组件包含服务提供器。应用程序所有注册在服务提供器的均列在 app/config/app.php 配置文件的 providers 数组中。
定义服务提供器
要创建服务提供器,只需继承 Illuminate\Support\ServiceProvider 类并且定义一个 register 方法:
use Illuminate\Support\ServiceProvider; class FooServiceProvider extends ServiceProvider { public function register() { $this->app->bind('foo', function() { return new Foo; }); } }
注意:在 register 方法,应用程序通过 $this->app 属性访问 IoC 容器。一旦你已经创建了提供器并且想将它注册到应用程序中, 只需简单的放入 app 配置文件里 providers 数组中。
运行时注册服务提供器
你也可以使用 App::register
方法在运行时注册服务提供器:
App::register('FooServiceProvider');
容器事件
注册获取事件监听者
容器在每次获取对象时都触发一个事件。你可以通过使用 resolving 方法来监听该事件:
App::resolvingAny(function($object) { // }); App::resolving('foo', function($foo) { // });
注意:获取到的对象将会传入回调函数中。
以上是Laravel框架中IOC容器的用法詳解的詳細內容。更多資訊請關注PHP中文網其他相關文章!