如何用Laravel包含你自己的幫助函數

很多教程都會說,你在 composer.json 這個文件中通過添加一個自動加載的文件,就可以實現這個需求。但我認為這不是一個好的方式,當你在 helpers.php 文件中添加瞭更多的函數時,可讀性將變得很差。

下面我將介紹一種方式,讓你可以定義很多文件,來包含不同的函數。這將讓我們的程序更加整潔和更具可讀性。

首先創建一個 HelperServiceProvider.php 服務提供者文件:

php artisan make:provider HelperServiceProvider

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

你可以簡單的移除 boot() 方法,我們在這兒不會使用它。

在 register() 方法中我們添加以下代碼:

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

這個循環將會遍歷 app/Heplers 目錄下的所有文件,你可能已經猜到瞭,現在你可以在這個目錄下隨便創建文件,它們將會被加載到你的應用程序中,這些幫助函數在你的代碼的任何地方都可以被訪問(views, models, controllers…)

我們還需要加載這個服務提供者,打開 config/app.php,然後將 HelperServiceProvider 放在你的 AppServiceProvider 上面

...
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目錄,其中包含您經常使用的幫助程序 

以上就是如何用Laravel包含你自己的幫助函數的詳細內容,更多關於用Laravel包含你自己的幫助函數的資料請關註WalkonNet其它相關文章!

推薦閱讀: