contracts, servicecontainer, serviceprovider, facades
1.Contracts 合同,契约,也就是接口,定义一些规则,每个实现此接口的都要实现里面的方法;
2.ServiceContainer,实现Contracts,具体的逻辑实现;
3.ServiceProvider, serviceContainer的服务提供者,返回ServiceContainer的实例化,供其他地方使用,可以把它加入到app/config的provider中,会被自动注册到容器中;
4.Facades, 简化ServiceProvider的调用方式,而且可以静态调用ServiceContainer中的方法;
实现
Contracts接口可以写或不写,这里就不定义了;
定义一个ServiceContainer,实现具体的功能
namespace AppHelper; class MyFoo { public function add($a, $b) { return $a+$b; } }
定义一个ServiceProvider供其他地方使用ServiceContain
<?php namespace AppProviders; use AppHelperMyFoo; //要服务的Container use IlluminateSupportServiceProvider; use App; class MyFooServiceProvider extends ServiceProvider { public function boot(){} //注册到容器中 public function register() { //可以这么绑定,这需要use App; App::bind("myfoo",function(){ return new MyFoo(); }); //也可以这么绑定 $this->app->bind("myfoo", function(){ return new MyFoo(); }); } }
在app/config.php中的providers数组中加入ServiceProvider,让系统自动注册
AppProvidersMyFooServiceProvider::class,
这时候就可以使用了,假设在控制器中使用
public function two($id=null) { //从系统容器中获取实例化对象 $myfoo = App::make("myfoo"); echo $myfoo->add(1,2); }
这样太麻烦,还需要用make来获取对象,为了简便,就可以使用门面功能,定义门面MyFooFacade
namespace AppFacades; use IlluminateSupportFacadesFacade; class MyFooFacade extends Facade { protected static function getFacadeAccessor() { //这里返回的是ServiceProvider中注册时,定义的字符串 return 'myfoo'; } }
在控制器里就可以直接调用了
use AppFacadesMyFooFacade; public function two($id=null) { //从系统容器中获取实例化对象 $myfoo = App::make("myfoo"); echo $myfoo->add(1,2); //使用门面 echo MyFooFacade::add(4,5); }
总的来说,自定义了一个类,为了方便在其他别处使用,便可以使用服务提供者和门面。
推荐:《laravel教程》
© 版权声明
文章版权归作者所有,未经允许请勿转载。
THE END
喜欢就支持一下吧
相关推荐