Laravel-包含你本身的帮助函数

文章转发自专业的Laravel开发者社区,原始连接: https://learnku.com/laravel/t...

你可能想建立一个在应用的任何地方均可以访问的函数,这个教程将帮你实现 👏php


不少教程都会说,你在 composer.json 这个文件中经过添加一个自动加载的文件,就能够实现这个需求。但我认为这不是一个好的方式,当你在 helpers.php 文件中添加了更多的函数时,可读性将变得不好。laravel

下面我将介绍一种方式,让你能够定义不少文件,来包含不一样的函数。这将让咱们的程序更加整洁和更具可读性。json

咱们开始吧.. 🔥app

首先建立一个 HelperServiceProvider.php 服务提供者文件:composer

php artisan make:provider HelperServiceProvider

使用上面命令,你将在 app\Providers 文件中生成 HelperServiceProvider.phpide

你能够简单的移除 boot() 方法,咱们在这儿不会使用它。函数

register() 方法中咱们添加如下代码:ui

public function register()
{
    foreach (glob(app_path('Helpers') . '/*.php') as $file) {
        require_once $file;
    }
}

这个循环将会遍历 app/Heplers 目录下的全部文件,你可能已经猜到了,如今你能够在这个目录下随便建立文件,它们将会被加载到你的应用程序中,这些帮助函数在你的代码的任何地方均可以被访问(views, models, controllers...)spa

咱们还须要加载这个服务提供者,打开 config/app.php,而后将 HelperServiceProvider 放在你的 AppServiceProvider 上面code

...
App\Providers\HelperServiceProvider::class,
App\Providers\AppServiceProvider::class,
App\Providers\AuthServiceProvider::class,
App\Providers\BroadcastServiceProvider::class,
...

如今让咱们建立一个简单的函数,在 app/Helpers 目录中建立一个 Carbon.php 文件,文件中包含如下代码:

<?php

/**
 * Carbon helper
 *
 * @param $time
 * @param $tz
 *
 * @return Carbon\Carbon
 */
function carbon($time = null, $tz = null)
{
    return new \Carbon\Carbon($time, $tz);
}

你不须要添加任何命令空间。若是你想,你可使用 function_exists 检测这个函数是否存在。

如今,你能够在应用程序的任何你喜欢的位置使用帮助函数 carbon()。如今,若是您须要另外一个返回特定格式的函数(仅针对本教程的用例),则能够在同一文件(Carbon.php)中输入该函数:

<?php

/**
 * Carbon helper
 *
 * @param $time
 * @param $tz
 *
 * @return Carbon\Carbon
 */
function carbon($time = null, $tz = null)
{
    return new \Carbon\Carbon($time, $tz);
}
function carbonFormatted($time = null, $tz = null)
{
    return carbon($time, $tz)->format('Y-m-d')
}

好的! 如今,您能够开始使用本身的PHP文件填充 app / Helpers目录,其中包含您常常使用的帮助程序 💪

注意:请记住,我是荷兰人,英语不是个人母语,所以本文可能包含一些语法错误。

相关文章
相关标签/搜索