**网上很多laravel的自定义facades,但是在5.2版本中讲述的就很少。用于个人记录也仅供参考**
首先建立Facades目录结构
在 app 目录下新建 Facades 文件夹,里面新建 Facades/Darry/Darry.php 和 Facades/Darry/Facade/Darry.php
(在Facades下面一个文件加表示一个facade注意区分,在文件夹下区分Facade与扩展类)
Facades/Darry 下的 Darry.php 是你要对 Darry 扩展进行封装的类。
而 Facades/Darry/Facade 下的 Darry.php 是你的 facade,用来给 laravel 解析使用,这两个文件可以不同名。
路径和文件名可以根据个人情况命名和设置。
//path:Facades/Darry/Darry.php
<?php
namespace App\Facades\Darry;
class Darry
{
/**
* @param $code 编码
* @param string $data 数据
* @param string $msg 信息
* @return string
*/
public static function json($code='', $data='' ,$msg='') {
return json_encode(array('code' => $code, 'data' => $data, 'msg' => $msg,));
}
//paht:Facades/Darry/Facade/Darry.php
<?php
namespace App\Facades\Darry\Facade;
use Illuminate\Support\Facades\Facade;
class DarryFacade extends Facade
{
protected static function getFacadeAccessor() {
return 'darry';// 返回了一个字符串 'darry' , 这个字符串是一个标号,用来给 laravel 的服务提供者解析使用的
}
}
?>
新建服务提供文件app/Providers/DarryFacadeServiceProvider.php
php artisan make:provider DarryFacadeServiceProvider
//paht:app/providers/DarryFacadeServiceProvider
<?php
namespace App\Providers;
use Illuminate\Support\ServiceProvider;
use App\Facades\Darry\Darry;
class DarryFacadeServiceProvider extends ServiceProvider
{
/**
* 在容器中注册绑定。
*
* @return void
*/
public function register()
{
$this->app->singleton('darry', function ($app) {
return new Darry($app);
});
}
}
最后就是注册和添加别名
//在config/app.php找到providers添加
App\Providers\DarryFacadeServiceProvider::class,
//在config/app.php找到aliases添加
'Darry' => App\Facades\Darry\Darry::class
尽情的使用吧
引入Darry:use Darry
调用方法:Darry::json();
**粗体** _斜体_ [链接](http://example.com) `代码` - 列表 > 引用
。你还可以使用@
来通知其他用户。