很多教程都會說,你在 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包含你自己的幫助函數的資料請關注腳本之家其它相關文章!
您可能感興趣的文章:- 淺談Laravel中使用Slack進行異常通知
- 詳解Laravel框架的依賴注入功能
- php+laravel 掃碼二維碼簽到功能
- laravel的數據表填充器使用詳解
- laravel ajax curd 搜索登錄判斷功能的實現
- Laravel中Kafka的使用詳解
- laravel使用redis隊列實例講解
- Laravel的加密解密與哈希實例講解
- Laravel中10個有用的用法小結
- 分析五個Laravel Dusk的使用技巧