你可能想建立一个在应用的任何地方均可以访问的函数,这个教程将帮你实现 👏php
不少教程都会说,你在 composer.json 这个文件中经过添加一个自动加载的文件,就能够实现这个需求。但我认为这不是一个好的方式,当你在 helpers.php 文件中添加了更多的函数时,可读性将变得不好。json
下面我将介绍一种方式,让你能够定义不少文件,来包含不一样的函数。这将让咱们的程序更加整洁和更具可读性。app
咱们开始吧.. 🔥composer
首先建立一个 HelperServiceProvider.php 服务提供者文件:ide
php artisan make:provider HelperServiceProvider
使用上面命令,你将在 app\Providers 文件中生成 HelperServiceProvider.php函数
你能够简单的移除 boot() 方法,咱们在这儿不会使用它。ui
在 register() 方法中咱们添加如下代码:spa
1 public function register() 2 { 3 foreach (glob(app_path('Helpers') . '/*.php') as $file) { 4 require_once $file; 5 } 6 }
这个循环将会遍历 app/Heplers 目录下的全部文件,你可能已经猜到了,如今你能够在这个目录下随便建立文件,它们将会被加载到你的应用程序中,这些帮助函数在你的代码的任何地方均可以被访问(views, models, controllers...)code
咱们还须要加载这个服务提供者,打开 config/app.php,而后将 HelperServiceProvider 放在你的 AppServiceProvider 上面orm
... App\Providers\HelperServiceProvider::class, App\Providers\AppServiceProvider::class, App\Providers\AuthServiceProvider::class, App\Providers\BroadcastServiceProvider::class, ...
如今让咱们建立一个简单的函数,在 app/Helpers 目录中建立一个 Carbon.php 文件,文件中包含如下代码:
1 <?php 2 3 /** 4 * Carbon helper 5 * 6 * @param $time 7 * @param $tz 8 * 9 * @return Carbon\Carbon 10 */ 11 function carbon($time = null, $tz = null) 12 { 13 return new \Carbon\Carbon($time, $tz); 14 }
你不须要添加任何命令空间。若是你想,你可使用 function_exists 检测这个函数是否存在。
如今,你能够在应用程序的任何你喜欢的位置使用帮助函数 carbon()。如今,若是您须要另外一个返回特定格式的函数(仅针对本教程的用例),则能够在同一文件(Carbon.php)中输入该函数:
1 <?php 2 3 /** 4 * Carbon helper 5 * 6 * @param $time 7 * @param $tz 8 * 9 * @return Carbon\Carbon 10 */ 11 function carbon($time = null, $tz = null) 12 { 13 return new \Carbon\Carbon($time, $tz); 14 } 15 function carbonFormatted($time = null, $tz = null) 16 { 17 return carbon($time, $tz)->format('Y-m-d') 18 }
好的! 如今,您能够开始使用本身的PHP文件填充 app / Helpers目录,其中包含您常常使用的帮助程序 💪