ホームページ > PHPフレームワーク > Laravel > 独自のコード生成パッケージを作成する laravel-generator

独自のコード生成パッケージを作成する laravel-generator

藏色散人
リリース: 2020-09-28 13:28:27
転載
2176 人が閲覧しました

次のチュートリアルこのコラムでは、コード生成パッケージ laravel-generator について紹介します。

独自のコード生成パッケージを作成する laravel-generator

Laravel ジェネレーター コード生成パッケージ

https://github.com/HogenYuan/laravel -generator

はじめに

最近バックエンドで作業しているため、Gii に似たコード生成パッケージが必要です。他にもあるかもしれません。インターネット上には豊富なパッケージがありますが、あまり知識がなかったので、自分の癖で使いやすいパッケージを書いただけで、急いで書いたのでコードが荒いかもしれません。まだバックエンドしか書いていないので、時間ができたらフロントエンドも書きたいと思います。 1. *.stub を変更して、カスタム フレームワーク ディレクトリに基づいてカスタマイズされた初期コードを生成します

2.

モデル フィルター要求リソース サービス コントローラー移行テストのサポート

3. 同じ名前のデータ テーブルを自動的に読み取り、モデル リソースの移行


インストール

のフィールドに入力します。

composer require hogen\laravel-generator

php artisan vendor:publish --tag=generator
ログイン後にコピー
config/app.php

'providers' => [

    ···    App\Console\Commands\Generator\GeneratorServiceProvider::class];
ログイン後にコピー
  • Run

独自のフレームワークに従ってデフォルトを変更してください最初にディレクトリとコード形式 コード形式スタブ ファイル

## name : 必填,短横式命名的资源名称}## --module= : 必填,指定三级模块(大小写规范) 如:GasStation/MainCard/Balance## --prefix= : 指定二级前缀(大小写规范) 默认:AdminApi## --baseDir= : 指定一级目录(大小写规范) 默认:Http## --force : 覆盖已存在文件## --filter : 使用filter筛选类## --test : 生成测试文件例子:

//有大小写规范

* Path: App\Http\Controller\AdminApi\User\Example 

php artisan admin:make-resource testExample --force --baseDir=Http --prefix=AdminApi --module=User\Example

* Path: App\Admin\Controller\User\Example

php artisan admin:make-resource testExample --force --filter --baseDir=Admin  --module=User\Example
ログイン後にコピー
  • デプロイメント カスタム構成

Generator\MakeResource.php

protected $types = [

    'model', 'request', 'resource', 'service', 'controller', 'test', 'migration'];
ログイン後にコピー

生成する必要があるコンポーネントを選択してください。フィルタとテストはデフォルトでは有効になっていません。

  • シーケンスがあります。順序を記入する必要があります。上の図によると

  • ディレクトリ ルール
protected $pathFormat = [

    'model'      => ['inBaseDir' => false, 'prefix' => ''],

    'service'    => ['inBaseDir' => false, 'prefix' => ''],

    'test'       => ['inBaseDir' => false, 'prefix' => true],

    'request'    => ['inBaseDir' => true, 'prefix' => true],

    'resource'   => ['inBaseDir' => true, 'prefix' => true],

    'controller' => ['inBaseDir' => true, 'prefix' => true],

    'migration'  => ['inBaseDir' => false, 'prefix' => ''],];
ログイン後にコピー

ここで各モジュールのパス ルール設定を変更します。各ファイルの名前空間とクラス名に影響を与えます

  • inBaseDir はそれが BaseDir 内にあるかどうかを決定します。デフォルトは

    Http
  • # です#prefix はセカンダリ プレフィックス内にあるかどうかを決定します

  • フィルター filter

protected $createFilter = false;protected $baseFilterHelperPath = "Models\Traits\Filter";
ログイン後にコピー

デフォルトでは有効になっていません

  • 生成されたフィルター基本クラスのパスの例: App/Models/Traits/Filter.php

  • パスの生成はモデルの inBaseDir ルールのみに従います。 $pathFormat にあり、個々の特性の生成を避けるためにプレフィックスに従いません

  • #データベース フィールドの充填

    #

    /**
    
     * 手动配置
    
     * resource文件中不需要添加到 $fillable 的字段
    
     *
    
     * @var string[]
    
     */protected $resourceNoFillableFields = [
    
        'update_time',
    
        'updated_time',
    
        'delete_time',
    
        'deleted_time',];/**
    
     * 手动配置
    
     * model文件中不需要添加到 $fillable 的字段
    
     *
    
     * @var string[]
    
     */protected $modelNoFillableFields = [
    
        'id',
    
        'create_time',
    
        'created_time',
    
        'update_time',
    
        'updated_time',
    
        'delete_time',
    
        'deleted_time',];
    ログイン後にコピー
  • コード形式デフォルトのコード形式を変更する

デフォルト形式をカスタマイズするには、各スタブ構成を参照してください。

次のスタブは、簡略化されたコード習慣です。 、必要に応じて変更します
  • Generator\stubs\*.stub

    <?php
    
    namespace DummyNamespace;
    
    use NamespacedDummyModel;
    
    use NamespacedDummyRequest;
    
    use NamespacedDummyResource;
    
    use NamespacedDummyService;
    
    use BaseNamespaceResource\EmptyResource;
    
    use BaseNamespaceController\Controller;
    
    class DummyClass extends Controller
    
    {
    
        public function index(DummyRequest $request){
    
            $validated = $request->validated();
    
            $dummyModels = DummyModel::query()
    
                ->filter($validated)
    
                ->orderByDesc(&#39;id&#39;)
    
                ->paginate();
    
            return DummyResource::collection($dummyModels);
    
        }
    
        ···
    
    }
    ログイン後にコピー
  • TODO

フロントエンドはコンポーネントに基づいて生成されます

##

以上が独自のコード生成パッケージを作成する laravel-generatorの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

関連ラベル:
ソース:learnku.com
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
最新の問題
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート