您好,登錄后才能下訂單哦!
這篇文章將為大家詳細講解有關Laravel模塊化是什么,文章內容質量較高,因此小編分享給大家做個參考,希望大家閱讀完這篇文章后對相關知識有一定的了解。
最近項目想用 Laravel 框架做開發,但考慮到隨著項目的增大,代碼的增多,需求變的復雜多樣化,將所有代碼寫在一起,無疑是一個很大的問題,這將導致代碼過于復雜,一些寫過的功能點想要重新使用,查找起來太過費勁;所以考慮到使用和其他框架類似的模塊化開發,但是 laravel 框架沒有明確的模塊化劃分,所以就想找一下看是否有其他第三方模塊化(Module)開發包來使用,畢竟 laravel 社區這么火熱和強大,最終找到了模塊化開發包,還比較好用,所以總結一下,分享出來。
這里使用的第三方鏡像包是:nwidart/laravel-modules,laravel 的模塊管理器。用起來很方便,git 地址:https://github.com/nWidart/laravel-modules
接下來就說一下使用的情況:
安裝:
使用 composer 快捷安裝:
composer require nwidart/laravel-modules
當然這一步是要建立在你本地已經安裝了 composer 的情況下。不會安裝 composer 可以查看官方說明,地址:https://getcomposer.org/download/
添加服務提供者:
接下來在 config /app.php 中添加以下服務提供者。
'providers' => [ Nwidart\Modules\LaravelModulesServiceProvider::class, ],
添加別名到同一文件的別名數組中。
以上兩步是進行服務注冊,必須要進行添加,不過在 laravel5.5 版本之后可以不添加也能運行,這得益于 laravel5.5 提供的包自動發現機制。
接下來發布軟件包的配置,通過運行以下方式:
php artisan vendor:publish --provider="Nwidart\Modules\LaravelModulesServiceProvider"
執行完上面這條命令之后,在 config 文件夾下會生成一個 modules.php 文件,這個是模塊開發的配置文件,你可以在這里面進行配置。
添加自動加載:
默認情況下,模塊類不會自動加載。 您可以使用 psr-4 自動加載模塊。
修改文件:composer.json
{ "autoload": { "psr-4": { "App\\": "app/", "Modules\\": "Modules/" } } }
提示:不要忘記運行 composer dump-autoload 命令。
生成模塊
接下來生成需要的模塊,使用以下命令:
php artisan module:make module-name
如果需要一次生成多個模塊,可以使用以下命令:
php artisan module:make module-name1 module-name2 module-name3
文件結構
執行上面的生成模塊命令,會生成如下文件結構:
如執行命令:php artisan module:make Blog
app/ bootstrap/ vendor/ Modules/ ├── Blog/ ├── Assets/ ├── Config/ ├── Console/ ├── Database/ ├── Migrations/ ├── Seeders/ ├── Entities/ ├── Http/ ├── Controllers/ ├── Middleware/ ├── Requests/ ├── routes.php ├── Providers/ ├── BlogServiceProvider.php ├── Resources/ ├── lang/ ├── views/ ├── Repositories/ ├── Tests/ ├── composer.json ├── module.json ├── start.php
至此,鏡像包安裝和使用已經完成,可以正常使用了。
模塊位置修改
由于以上生成的目錄結構的模塊是在和 app 同級的目錄下,我想把他放到 app 目錄下面,這樣看起來會好一點(個人習慣,可不必修改)。
方法:修改配置文件 config/modules.php 文件
'namespace' => 'App\Modules', 'paths' => [ 'modules' => base_path('App\Modules'), ]
現在執行生成模塊命令,生成的 Modules 模塊會在 app 目錄下面。
路由修改
使用 nwidart/laravel-modules 鏡像包安裝的路由文件默認是在 Blog/Http/routes.php 下面,而使用路由是由模塊生成的 start.php 文件加載的。我想把他提取出來,放到單獨的文件夾下面,像 laravel 的路由一樣(個人習慣,可不必修改)。
方法:修改配置文件 config/modules.php 文件
①將配置文件中有關 start 的配置去掉
'stubs' => [ 'enabled' => false, 'path' => base_path() . '/vendor/nwidart/laravel-modules/src/Commands/stubs', 'files' => [ // 'start' => 'start.php', 'routes' => 'Http/routes.php', ], 'replacements' => [ // 'start' => ['LOWER_NAME'], ], ],
接下來再將 Blog/module.json 下面生成的 start.php 去掉
{ "files": [], }
以上兩步是為了避免程序執行期間報錯,所以必須執行。
②修改路由文件生成路徑
'stubs' => [ 'files' => [ // 'start' => 'start.php', 'routes' => 'Routes/routes.php', ],
現在執行生成模塊命令,生成的路由文件會在 Blog/Routes/route.php 模塊下面。
③接下來修改路由服務提供者,注冊路由
執行命令:
php artisan module:route-provider Blog
為指定的模塊生成給定的路由。
執行完此命令之后,會在 Blog/Providers 目錄下面生成一個 RouteServiceProvider.php 文件,此文件就是路由的服務提供者。
接下來修改 RouteServiceProvider.php 文件
public function map(Router $router) { // if (!app()->routesAreCached()) { // require __DIR__ . '/Http/routes.php'; // } if (! app()->routesAreCached()) { $this->mapWebRoutes(); } }
增加方法:
protected function mapWebRoutes() { //方法一: //Route::group([ //'middleware' => 'web', //'namespace' => $this->namespace, //], function ($router) { //require module_path('Admin') . '/Routes/routes.php'; //}); //方法二: Route::middleware('web') ->namespace($this->rootUrlNamespace) ->group(module_path('Blog') . '/Routes/routes.php'); }
在此 RouteServiceProvider.php 文件已經修改完畢。
接下來修改 Blog/Providers/BlogServiceProvider.php 文件,修改如下:
public function register() { //注冊服務提供者 $this->app->register(RouteServiceProvider::class); }
到此使用第三方鏡像包,開發 laravel 模塊化項目已經說明完畢,希望對大家有用。
關于Laravel模塊化是什么就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。