脚本宝典收集整理的这篇文章主要介绍了Laravel5.2 自定义Facades,脚本宝典觉得挺不错的,现在分享给大家,也给大家做个参考。
**网上很多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 AppFacadesDarry;
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 AppFacadesDarryFacade;
use IlluminateSupportFacadesFacade;
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 AppProviders;
use IlluminateSupportServiceProvider;
use AppFacadesDarryDarry;
class DarryFacadeServiceProvider extends ServiceProvider
{
/**
* 在容器中注册绑定。
*
* @return void
*/
public function register()
{
$this->app->singleton('darry', function ($app) {
return new Darry($app);
});
}
}
最后就是注册和添加别名
//在config/app.php找到providers添加
AppProvidersDarryFacadeServiceProvider::class,
//在config/app.php找到aliases添加
'Darry' => AppFacadesDarryDarry::class
尽情的使用吧
引入Darry:use Darry
调用方法:Darry::json();
以上是脚本宝典为你收集整理的Laravel5.2 自定义Facades全部内容,希望文章能够帮你解决Laravel5.2 自定义Facades所遇到的问题。
本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。