一 、简单粗鲁(用于本地测试)
路由中定义:
Event::listen('eloquent.updated: App\Post',function (){
dump('测试一下修改事件');
});
Route::post('/post/{id}', 'PostController@update');
二 、生成事件和监听器
在 EventServiceProvider 定义对应关系
protected $listen = [
'App\Events\PostEvent' => [
'App\Listeners\PostListener',
],
];
php artisan event:generate //生成文件
event 中注入要操作的类
listen 中handle 方法注入对应事件类
public function handle(PostEvent $event)
{
dump('测试一下修改事件');
}
最后在 post 模型中添加 'events' 属性
protected $events = [
'updated' => PostListener::class
];
三 、利用框架的 boot 方法
直接在相关
Model
中定义
public static function boot() {
parent::boot();
static::updated(function($model) {
dump('测试一下修改事件');
});
}
四 、定义Trait
如果想对多个模型的updated 或 created 事件进行一些操作,该不会每个模型都单独写一个吧.例如:
日志
.
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 - 恢复软删除后
**粗体** _斜体_ [链接](http://example.com) `代码` - 列表 > 引用
。你还可以使用@
来通知其他用户。