首页 > 后端开发 > php教程 > Laravel 观察者:应用程序生命周期中的沉默忍者

Laravel 观察者:应用程序生命周期中的沉默忍者

Linda Hamilton
发布: 2024-11-08 02:00:02
原创
671 人浏览过

Laravel Observers: The Silent Ninjas of Your Application Lifecycle

简介

想象一下,每当您在网站上提交表单时,一个隐形助手就会进来并再次检查所有内容。添加更多详细信息,甚至无需您费力即可发送一封欢迎信。 Laravel 观察者就像默默工作的幕后助手。而且它的功能强大,可以在您需要时处理所有任务。在这篇文章中,我们将深入探讨观察者在 Laravel 中的工作方式,以及为什么它们是应用程序在模型事件处理中的沉默忍者。以及如何在现实世界的示例中充分利用这些事件。

什么是 Laravel 观察者?

Laravel 观察者是侦听器类,可通过观察特定事件(例如创建、更新或删除)来帮助管理模型的生命周期。观察者可以为每个事件定义操作。保持您的控制器和模型干净且专注。观察者在您的应用程序中充当“事件专家”。观察者将处理改进代码库所需的后端工作。通过事件驱动的工作分离来提高组织和效率。观察者有助于构建更加模块化和可维护的应用程序结构。

为什么使用观察者?

1。更干净的控制器和模型:观察者处理重复的动作,让您的控制器和模型专注于他们的主要工作而不会分心。

2。代码可重用性:您可以将相关操作整合到一个地方,使您的代码更具可读性和可维护性。

3。错误处理: 每当模型发生变化时,观察者都会自动执行数据验证或后台更新等任务,从而帮助您避免错误。

4。自动事件处理:想要在每次创建或更新记录时触发操作?观察员为您提供支持。

简而言之,观察者非常适合组织您想要在应用程序生命周期的各个阶段执行的逻辑。

Eloquent Hooks 概述:

- 已检索: 从数据库检索记录后触发。
- 创建: 在创建新记录之前触发。
- Created: 成功创建新记录后执行。
- 更新: 在更新现有记录之前激活。
- 更新: 更新记录后触发。
- 保存: 在保存记录之前运行,无论是新创建还是更新。
- 已保存: 保存记录后发生,无论是新创建的还是更新的。
- 删除: 在删除或软删除记录之前启动。
- 已删除: 删除或软删除记录后激活。
- 恢复: 在恢复软删除记录之前触发。
- 已恢复: 在成功恢复软删除记录后运行。

分步指南:如何创建和使用观察者

让我们用一个现实世界的例子来讨论观察者。想象一下,我们正在构建一个博客应用程序,每次用户发布帖子时,我们都希望:

  • 根据标题自动生成 slug。
  • 通知管理员。
  • 记录发布日期。

以下是我们如何使用 Laravel Observers 实现这一目标!

第 1 步:创建观察者类
Laravel 可以轻松生成观察者类。运行此命令:

php artisan make:observer PostObserver --model=Post
登录后复制
登录后复制

这将在 app/Observers 目录中生成一个 PostObserver 类并将其链接到我们的 Post 模型。

第 2 步:在观察者中定义事件

打开PostObserver类,你会看到一些已经存在的方便的方法。每个方法对应一个模型事件,如创建、更新、删除等。

让我们将自定义逻辑添加到创建事件中,以便它生成一个 slug 并记录发布日期:

use Illuminate\Support\Str;
class PostObserver
{
   public function creating(Post $post)
   {
       $post->slug = Str::slug($post->title);
       $post->published_at = now();
   }

   public function created(Post $post)
   {
      Notification::send(User::admin(), new PostPublishedNotification($post));
   }
}
登录后复制

第 3 步:注册观察者

Laravel 提供了两种方法来做到这一点:模型上的 ObservedBy 属性或手动使用observe 方法

1.使用 ObservedBy 属性

如果您使用 Laravel 10 ,您可以直接在模型上使用 ObservedBy 属性。此属性通过自动将观察者链接到模型来简化观察者注册:

use App\Observers\PostObserver;
use Illuminate\Database\Eloquent\Concerns\ObservedBy;

#[ObservedBy(PostObserver::class)]
class Post extends Model
{
   // Your Post model code
}
登录后复制

这种方法很干净,可以让观察者注册到模型本身,减少设置步骤并保持 AppServiceProvider 不变。

2.手动注册观察者
如果您愿意(或者正在使用 10 之前的 Laravel 版本),您可以在 AppServiceProvider 的 boot 方法中手动注册 Observer:

在您的AppProvidersAppServiceProvider.php中,添加observe方法以将观察者链接到模型:

php artisan make:observer PostObserver --model=Post
登录后复制
登录后复制

注册后,只要 Post 模型上发生相应的事件,Laravel 就会触发你的 Observer 的方法。

第 4 步:测试你的观察者

要查看观察者的实际情况,请尝试在您的应用中创建或更新帖子。 slug 将自动生成,发布日期将自行设置,我们假设的管理员将收到通知。观察者让这一切悄然发生,就像真正的忍者一样。


感谢您的阅读!我希望这能为您的项目激发一些新的想法。如果您有兴趣将高质量的开发变为现实,请随时与我们联系——我很乐意与您联系并探索我们如何实现这一目标。

以上是Laravel 观察者:应用程序生命周期中的沉默忍者的详细内容。更多信息请关注PHP中文网其他相关文章!

来源:dev.to
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
作者最新文章
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板