Laravelでモデルイベントを使用する方法について話しましょう
Eloquent モデルを使用する場合、モデルのライフサイクルを通じてディスパッチされるイベントを利用するのが一般的です。これを行うにはいくつかの異なる方法があり、このチュートリアルではそれらを取り上げ、それぞれの長所と短所を説明します。 [関連する推奨事項: laravel ビデオ チュートリアル ]
直接比較できるように、各メソッドに同じ例を使用します。この例では、モデル自体の作成中に、モデルの UUID プロパティを UUID に割り当てます。
最初のアプローチでは、モデルの静的ブートストラップ メソッドを使用して動作を登録します。これにより、モデルを直接操作し、モデルの作成時にモデルを作成できるようになります。
declare(strict_types=1); namespace App\Models; use Illuminate\Database\Eloquent\Model; use Illuminate\Support\Str; class Office extends Model { public static function boot(): void { static::creating(fn (Model $model) => $model->uuid = Str::uuid(), ); } }
このアプローチは、非常に理解しやすく、モデルで何が起こっているかを正確に確認できるため、UUID の追加など、モデル イベントに対する小規模で直接的な反応に最適です。このアプローチの最大の問題はコードの重複です。UUID を割り当てる必要があるモデルが複数ある場合、同じことを繰り返し行うことになります。
これにより、機能を使用する 2 番目のアプローチにうまくつながります。 Laravel では、boot
で始まりトレイト名で終わるトレイトのメソッドを作成すると、モデルはトレイトを継承して自動的に開始できます。以下に例を示します。
declare(strict_types=1); namespace App\Models\Concerns; use Illuminate\Database\Eloquent\Model; use Illuminate\Support\Str; trait HasUuid { public static function bootHasUuid(): void { static::creating(fn (Model $model) => $model->uuid = Str::uuid(), ); } }
トレイトを使用すると、この動作を必要とするすべてのモデルにこの動作を追加でき、実装が簡単になります。私の最大の欠点は、複数の機能が同じモデル イベントを利用したい場合に、これらの動作を積み重ねると問題が発生する可能性があることです。彼らは優先順位をめぐって争い始め、すぐに混乱してしまいます。
これにより、次のオプションであるモデル オブザーバーが表示されます。モデル オブザーバーは、モデル イベントに応答するクラスベースの方法であり、メソッドはトリガーされた特定のイベントに対応します。
declare(strict_types=1); namespace App\Observers; use Illuminate\Database\Eloquent\Model; use Illuminate\Support\Str; class OfficeObserver { public function creating(Model $model): void { $model->uuid = Str::uuid(); } }
このクラスは、サービス プロバイダーまたはモデル自体のどこかに登録する必要があります (これをお勧めします)。このオブザーバーをモデルに登録すると、雄弁な動作の変化による副作用をモデル レベルで確認できるようになります。サービスプロバイダーからそれを隠す場合の問題は、誰もがその存在を知らない限り、それを知るのが難しいことです。このアプローチの最大の欠点は、その可視性です。私の意見では、この方法は正しく使えば素晴らしいものです。
この問題を解決するもう 1 つの方法は、Eloquent モデル自体の $dispatchesEvents
プロパティを利用することです。これは、すべての Eloquent モデルのプロパティであり、リッスンするイベントと、それらのイベントに対して呼び出すクラスをリストすることができます。
declare(strict_types=1); namespace App\Models; use Illuminate\Database\Eloquent\Model; use Illuminate\Support\Str; class Office extends Model { protected $dispatchesEvents = [ 'creating' => SetModelUuid::class, ]; }
SetModelUuid
は、Eloquent モデルのライフ サイクル中にインスタンス化されます。これは、モデルに動作とプロパティを追加する機会となります。
declare(strict_types=1); namespace App\Models\Events; use Illuminate\Database\Eloquent\Model; use Illuminate\Support\Str; class SetModelUuid { public function __construct(Model $model) { $model->uuid = Str::uuid(); } }
このアプローチは、モデルの可視性が高く、このクラスをモデル間で簡単に共有できるため、最もクリーンで理解しやすいアプローチの 1 つです。直面する最大の疑問は、モデル イベントに対して複数のアクションをトリガーする必要があるかどうかです。
とにかく、正直に言って、これを行う正しい方法はありません。上記の方法のいずれかを選択でき、すべて機能しますが、自分と特定の使用例に適した方法を選択する必要があります。この特定の機能に関するオプションをもっと増やしてほしいと思います。
たとえば、モデル イベントでモデルに複数のプロパティを追加する必要がある場合は、オブザーバーが適しています。しかし、これが最善の選択肢でしょうか?このモデルのカスタム パイプラインを実行するためにディスパッチ イベント属性を使用するとどうなるでしょうか?
declare(strict_types=1); namespace App\Models\Pipelines; use App\Models\Office class OfficeCreatingPipeline { public function __construct(Office $model) { app(Pipeline::class) ->send($model) ->through([ ApplyUuidProperty::class, TapCreatedBy::class, ]); } }
ご覧のとおり、パイプラインの使用を開始して、イベント モデリング用の複数の動作を追加できます。これはまだテストされていないので、それが可能かどうかは 100% わかりませんが、概念としては、モデル イベントに反応する構成可能な方法を開く可能性があります。
Laravel プロジェクトでモデル イベントをどのように処理しますか? Twitterで教えてください!
元のアドレス: https://laravel-news.com/working-with-laravel-model-events
翻訳アドレス: https://learnku.com/laravel/ t/71183
プログラミング関連の知識については、プログラミング ビデオをご覧ください。 !
以上がLaravelでモデルイベントを使用する方法について話しましょうの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 中国語版
中国語版、とても使いやすい

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック









JWTは、JSONに基づくオープン標準であり、主にアイデンティティ認証と情報交換のために、当事者間で情報を安全に送信するために使用されます。 1。JWTは、ヘッダー、ペイロード、署名の3つの部分で構成されています。 2。JWTの実用的な原則には、JWTの生成、JWTの検証、ペイロードの解析という3つのステップが含まれます。 3. PHPでの認証にJWTを使用する場合、JWTを生成および検証でき、ユーザーの役割と許可情報を高度な使用に含めることができます。 4.一般的なエラーには、署名検証障害、トークンの有効期限、およびペイロードが大きくなります。デバッグスキルには、デバッグツールの使用とロギングが含まれます。 5.パフォーマンスの最適化とベストプラクティスには、適切な署名アルゴリズムの使用、有効期間を合理的に設定することが含まれます。

静的結合(静的::) PHPで後期静的結合(LSB)を実装し、クラスを定義するのではなく、静的コンテキストで呼び出しクラスを参照できるようにします。 1)解析プロセスは実行時に実行されます。2)継承関係のコールクラスを検索します。3)パフォーマンスオーバーヘッドをもたらす可能性があります。

PHPの魔法の方法は何ですか? PHPの魔法の方法には次のものが含まれます。1。\ _ \ _コンストラクト、オブジェクトの初期化に使用されます。 2。\ _ \ _リソースのクリーンアップに使用される破壊。 3。\ _ \ _呼び出し、存在しないメソッド呼び出しを処理します。 4。\ _ \ _ get、dynamic属性アクセスを実装します。 5。\ _ \ _セット、動的属性設定を実装します。これらの方法は、特定の状況で自動的に呼び出され、コードの柔軟性と効率を向上させます。

Laravelの電子メールの送信が失敗したときに戻りコードを取得する方法。 Laravelを使用してアプリケーションを開発する場合、検証コードを送信する必要がある状況に遭遇することがよくあります。そして実際には...

PHP8では、一致式は、式の値に基づいて異なる結果を返す新しい制御構造です。 1)Switchステートメントに似ていますが、実行ステートメントブロックの代わりに値を返します。 2)一致式の式は厳密に比較され、セキュリティが向上します。 3)スイッチステートメントの脱落の可能性を回避し、コードのシンプルさと読みやすさを向上させます。

PHPでは、予測不可能なトークンを使用して、CSRF攻撃を効果的に防ぐことができます。特定の方法には次のものが含まれます。1。フォームのCSRFトークンを生成および埋め込みます。 2.リクエストを処理するときにトークンの有効性を確認します。

PHPの厳格なタイプは、declare(strict_types = 1)を追加することで有効になります。ファイルの上部に。 1)関数パラメーターのタイプチェックと戻り値を強制して、暗黙の型変換を防ぎます。 2)厳格なタイプを使用すると、コードの信頼性と予測可能性を改善し、バグを減らし、保守性と読みやすさを向上させることができます。

PHPでは、最終的なキーワードを使用して、クラスが継承されないようにし、メソッドが上書きされます。 1)クラスを決勝としてマークする場合、クラスを継承することはできません。 2)メソッドを最終的にマークする場合、メソッドはサブクラスによって書き換えられません。最終的なキーワードを使用すると、コードの安定性とセキュリティが保証されます。
