如何用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其它相關文章!
推薦閱讀:
- laravel多視圖共享數據實例代碼
- 詳解Laravel服務容器的優勢
- Laravel 重寫日志,讓日志更優雅
- laravel yajra插件 datatable的使用詳解
- 詳解Laravel框架的依賴註入功能