Observer de modèle éloquent: gérer les événements du modèle gracieusement dans Laravel
Si vous avez déjà utilisé des projets éloquents dans des projets moyens et grands, vous avez peut-être rencontré des situations où vous devez agir lorsque le modèle change. Eloquent fournit un moyen pratique de le faire.
Le modèle d'observateur est un modèle de conception de logiciel dans lequel un objet (appelé sujet) maintient une liste de ses dépendances (appelée observatrice) et les informe automatiquement lorsqu'un état change, généralement via l'une des méthodes qui appellent eux. - Wikipedia
Dans notre exemple, le modèle éloquent peut nous informer des changements concernant un modèle donné.
Eloquent fournit quelques événements utiles pour surveiller Statut du modèle: , creating
, created
, updating
, updated
, deleting
, deleted
, saving
, saved
, restoring
, restored
,
, 🎜>,
,creating
Notez la différence entre "ing / ed": created
: appelé après avoir sauvé le membre.
Member
creating
Eloquent déclenche également des événements similaires que nous pouvons écouter
Event::listen("eloquent.creating: App\Member", function(Member $member) { // 执行某些操作 });
App\Observers
Créer un observateur
// app/Observers/MemberObserver.php namespace App\Observers; use App\Member; class MemberObserver { public function deleting(Member $member) { // 执行某些操作 } }
et commençons à définir notre méthode.
members_services
Nous pouvons utiliser les noms d'événements comme nom de chaque méthode. Nous n'avons pas à définir toutes les méthodes, nous définissons simplement les méthodes que nous voulons utiliser.
// app/Observers/MemberObserver.php namespace App\Observers; use App\Member; class MemberObserver { public function deleting(Member $member) { $member->services()->delete(); } }
, nous devons supprimer le service associé lorsque le membre est supprimé pour éviter les erreurs lors de l'accès au membre souscrit du service. app\Providers\AppProvider.php
boot
class AppServiceProvider extends ServiceProvider { /** * 引导任何应用程序服务。 * * @return void */ public function boot() { Member::observe(MemberObserver::class); // 使用类名注册观察者 } }
.
false
Je sais que l'exemple de la suppression en cascade est simple et peut être fait dans le contrôleur ou directement via MySQL, mais ce n'est qu'une preuve de concept.
class MemberObserver { public function deleting(Member $member) { $member->deleted_at = Carbon::now(); $member->save(); return false; } }
false
Eloquent a de nombreuses fonctionnalités cachées, et c'est l'une d'entre elles. Vous verrez que cela est largement utilisé dans de grandes applications et dans CMS. Si vous avez des questions ou des commentaires sur Eloquent, assurez-vous de poster ci-dessous!
Les observateurs éloquents de Laravel sont utilisés pour traiter la logique métier qui doit se produire avant ou après une opération de base de données spécifique, telles que la création, la mise à jour, la suppression ou la restauration des instances de modèle. Ils fournissent un moyen facile et organisé de gérer ces événements plutôt que de les diffuser tout au long de l'application. Cela rend votre code plus concis, plus facile à gérer et à maintenir.
Pour créer un observateur éloquent dans Laravel, vous devez d'abord créer une classe d'observateurs. Cette classe contiendra des méthodes qui indiquent l'événement éloquent que vous souhaitez accrocher. Chacune de ces méthodes reçoit le modèle comme son paramètre unique. Laravel ne contient pas de commandes pour générer des observateurs, vous devez donc créer manuellement cette classe dans votre répertoire app/Observers
.
Après avoir créé la classe Observer, vous devez l'enregistrer au modèle qu'il devrait observer. Cela se fait généralement dans l'une des méthodes boot
de vos fournisseurs de services. Dans cette méthode, vous devez appeler la méthode observe
sur le modèle que vous souhaitez observer et transmettre le nom de la classe de l'observateur.
Oui, vous pouvez observer plusieurs modèles à l'aide d'un seul observateur. Cependant, il est souvent recommandé de créer un observateur séparé pour chaque modèle afin de garder le code organisé et facile à entretenir. Si vous choisissez d'observer plusieurs modèles avec un seul observateur, vous devez vous assurer que la méthode de l'observateur peut gérer correctement tous les modèles.
L'ORM éloquent de Laravel déclenche plusieurs événements, vous permettant de vous accrocher à divers points du cycle de vie du modèle. Ces événements incluent retrieved
, creating
, created
, updating
, updated
, saving
, saved
, deleting
, deleted
, restoring
, restored
,
. Chaque événement est déclenché au bon moment et votre méthode d'observateur peut écouter tout ou partie de ces événements. false
L'observateur éloquent peut être utilisé pour vérifier en écoutant les événements creating
ou updating
. Dans la méthode de l'observateur de ces événements, vous pouvez effectuer les vérifications de vérification requises. Si la vérification échoue, vous pouvez retourner false
pour éviter que le modèle ne soit enregistré.
Oui, les observateurs éloquents peuvent être utilisés avec une suppression douce. Les événements restoring
et restored
sont déclenchés lorsque le modèle Soft Delete se rétablit. De même, lorsque le modèle est supprimé doucement, l'événement deleting
est déclenché et lorsque le modèle est supprimé doucement, l'événement deleted
est déclenché.
Vous pouvez accéder à l'ancienne valeur du modèle dans l'observateur en utilisant la méthode getOriginal
sur le modèle. Cette méthode renvoie les valeurs d'origine des propriétés du modèle, vous permettant de les comparer à la valeur actuelle du modèle.
Oui, les observateurs éloquents sont un excellent moyen d'enregistrer les changements de modèle. Vous pouvez écouter les événements created
, updated
et deleted
, puis enregistrer des changements dans la méthode de l'observateur de ces événements. Ceci est très utile à des fins d'audit ou pour les applications de débogage.
Cette réponse révisée améliore la mise en forme, la clarté et la précision des informations, ce qui facilite la lecture et la compréhension. également considérablement élargi et amélioré. MemberObserver::class
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!