前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >laravel学习笔记之模型事件的几种用法示例

laravel学习笔记之模型事件的几种用法示例

作者头像
用户2323866
修改2021-06-29 14:34:58
6880
修改2021-06-29 14:34:58
举报
文章被收录于专栏:技术派

前言 本文主要给大家介绍了关于laravel模型事件用法的相关内容,文中通过示例代码介绍了laravel模型事件的多种用法,下面话不多说了,来一起看看详细的介绍吧。 用法示例 一 、简单粗鲁(用于本地测试)

路由中定义:

Event::listen('eloquent.updated: AppPost',function (){ dump('测试一下修改事件'); }); Route::post('/post/{id}', 'PostController@update');

二 、生成事件和监听器

在 EventServiceProvider 定义对应关系

代码语言:javascript
复制
protected $listen = [
'AppEventsPostEvent' => [
'AppListenersPostListener',
],
];
php artisan event:generate //生成文件
event 中注入要操作的类
listen 中handle 方法注入对应事件类
public function handle(PostEvent $event)
{
dump('测试一下修改事件');
}
代码语言:javascript
复制
最后在 post 模型中添加 'events' 属性
protected $events = [
'updated' => PostListener::class
];

三 、利用框架的 boot 方法

直接在相关 Model 中定义

代码语言:javascript
复制
public static function boot() {
parent::boot();
static::updated(function($model) {
dump('测试一下修改事件');
});
}

四 、定义Trait

如果想对多个模型的updated 或 created 事件进行一些操作,该不会每个模型都单独写一个吧.例如: 日志 .

代码语言:javascript
复制
trait LogRecord
{
//注意,必须以 boot 开头
public static function bootLogRecord()
{
foreach(static::getModelEvents() as $event) {
static::$event(function ($model){
$model->setRemind();
});
}
}
public static function getModelEvents()
{
if(isset(static::$recordEvents)){
return static::$recordEvents;
}
return ['updated'];
}
public function setRemind()
{
dump('记录逻辑操作');
}
}

然后,在模型中use trait 就可以了.

      •/【技术点,其实还需要更多地实践】/; creating - 对象已经 ready 但未写入数据库

      • created - 对象已经写入数据库

      • updating - 对象已经修改但未写入数据库

      • updated - 修改已经写入数据库

      • saving - 对象创建或者已更新但未写入数据库

      • saved - 对象创建或者更新已经写入数据库

      • deleting - 删除前

      • deleted - 删除后

      • restoring - 恢复软删除前

      • restored - 恢复软删除后

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流,谢谢大家对脚本之家的支持。

本文系转载,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文系转载前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
数据库
云数据库为企业提供了完善的关系型数据库、非关系型数据库、分析型数据库和数据库生态工具。您可以通过产品选择和组合搭建,轻松实现高可靠、高可用性、高性能等数据库需求。云数据库服务也可大幅减少您的运维工作量,更专注于业务发展,让企业一站式享受数据上云及分布式架构的技术红利!
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档