看过很多关于helper辅助文件的教程 我进行个进一步优化
很多教程都会说,你在 composer.json 这个文件中通过添加一个自动加载的文件,就可以实现这个需求。但我认为这不是一个好的方式,当你在 helpers.php 文件中添加了更多的函数时,可读性将变得很差。
下面我将介绍一种方式,让你可以定义很多文件,来包含不同的函数。这将让我们的程序更加整洁和更具可读性。
我们开始吧.. ?
首先创建一个 HelperServiceProvider.php 服务提供者文件:
php artisan make:provider HelperServiceProvider
使用上面命令,你将在 app\Providers 文件中生成 HelperServiceProvider.php
你可以简单的移除 boot() 方法,我们在这儿不会使用它。
在 register() 方法中我们添加以下代码:
public function register() { $this->directoryToArray(app_path('Helpers')); } private function directoryToArray($directory, $recursive = false) { $array_items = array(); if(!is_dir($directory)) return "$directory folder does not exist"; if ($handle = opendir($directory)) { while (false !== ($file = readdir($handle))) { if ($file != "." && $file != "..") { if (is_dir($directory. "/" . $file)) { if($recursive) { self::directoryToArray($directory. "/" . $file, $recursive); } if($this->validateExt($file)){ $file = $directory . "/" . $file; require_once $file; } } else { if($this->validateExt($file)){ $file = $directory . "/" . $file; require_once $file; } } } } closedir($handle); } } /*该段存在判断BUG 请废弃 private function validateExt($file){ $file_path = pathinfo($file); if($file_path ['extension'] == 'php'){ return true; } return false; }*/ private function validateExt($file){\ $file_path = pathinfo($file);\ Log::info($file_path);\ if(isset($file_path['extension'])){\ if($file_path['extension'] == 'php'){\ return true;\ }\ }\ return false;\ }
这个循环将会遍历 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文件填充 app / Helpers目录,其中包含您经常使用的帮助程序 ?
© 著作权归作者所有
发表评论