tp6模型事件的触发条件(详解)
Thinkphp6模型事件类似于Vue的钩子函数,方便我们在增、删、查、改这个时间段进行操作
模型事件
首先,从手册上,我们可以知道模型支持以下事件:
| 事件 | 描述 | 事件方法名 | 
|---|---|---|
| after_read | 查询后 | onAfterRead | 
| before_insert | 新增前 | onBeforeInsert | 
| after_insert | 新增后 | onAfterInsert | 
| before_update | 更新前 | onBeforeUpdate | 
| after_update | 更新后 | onAfterUpdate | 
| before_write | 写入前 | onBeforeWrite | 
| after_write | 写入后 | onAfterWrite | 
| before_delete | 删除前 | onBeforeDelete | 
| after_delete | 删除后 | onAfterDelete | 
| before_restore | 恢复前 | onBeforeRestore | 
| after_restore | 恢复后 | onAfterRestore | 
建立模型
为了了解每个事件的触发条件,我们先建立以下模型:
<?php
namespace app\model;
use think\Model;
class Article extends Model
{
    public static function onAfterRead($user) {
//        查询后:每次执行就查询一条数据
        dump('查询后');
//        halt($user);
    }
    public static function onBeforeInsert($user) {
//        新增前:获取的新增数据,还没新增
        dump('新增前');
//        halt($user->toArray());
    }
    public static function onAfterInsert($user) {
//        新增后:获取的新增数据,已经新增数据
        dump('新增后');
//        halt($user->toArray());
    }
    public static function onBeforeUpdate($user) {
//        更新前:获取的更新数据,还没更新数据
        dump('更新前');
//        halt($user->toArray());
    }
    public static function onAfterUpdate($user) {
//        更新后:获取的更新数据,已经更新数据
        dump('更新后');
//        halt($user->toArray());
    }
    public static function onBeforeWrite($user) {
//        写入前:获取的当前数据,还没新增、更新
        dump('写入前');
//        halt($user->toArray());
    }
    public static function onAfterWrite($user) {
//        写入后:获取的当前数据
        dump('写入后');
//        halt($user->toArray());
    }
    public static function onBeforeDelete($user) {
//        删除前:获取的删除前数据,还没删除
        dump('删除前');
//        halt($user->toArray());
    }
    public static function onAfterDelete($user) {
//        删除后:获取的删除数据,已经删除
        dump('删除后');
    }
    public static function onBeforeRestore($user) {
        dump('恢复前');
    }
    public static function onAfterRestore($user) {
        dump('恢复后');
    }
}
测试代码
然后通过以下代码去操作数据库:
public function demo9(Article $model){
//   查询后:数据有多少条onAfterRead就执行多少次,我的数据有9条,所有执行9次
    $model::select();
    //写入前、新增前、新增后、写入后
    $model::create([
        'title'=>'test1',
        'content'=>'111111111111111',
    ]);
    //写入前、新增前、新增后、写入后
    $model->save([
        'title'=>'test2',
        'content'=>'22222222222',
    ]);
    //查询后、写入前、更新前、写入后、更新后
    $art = $model::find(7);
    $art->save([
        'title'=>'test3',
        'content'=>'33333333333333',
    ]);
    //写入前、更新前、更新后、写入后
    $model->update([
        'id'=>8,
        'title'=>'test4',
        'content'=>'4444444444444',
    ]);
    //没有触发
    $model::where('id',11)->delete();
    //没有触发
    $model->insert([
        'title'=>'test1',
        'content'=>'111111111111',
    ]);
    //没有触发
    $model->where('id',8)->update([
        'title'=>'test4',
        'content'=>'4444444444444',
    ]);
    
    //查询后、删除前、删除后
    $art = $model::find(9);
    $art->delete();
    //查询后、删除前、删除后
    $model::destroy(13);
}
如果你想获取以前的数据进行对比,使用getOrigin:
public static function onAfterUpdate($user) {
    $origin = $user->getOrigin("category");//以前数据
    $category = $user['category'];//当前的数据
    if ($origin != $category) {
       //操作
    }
}    
总结
create()
模型创建数据方法,会触发写入前、新增前、新增后、写入后。使用模型的save()和saveAll()来新增方法也会触发这几个事件。
insert()
insert()是Db类的方法,不是模型方法,不会触发模型事件。
update()
update()模型方法,写入前、更新前、更新后、写入后。
如果是直接使用条件更新,则不会触发模型事件。因为直接使用条件更新,这时候的update()方法不是模型方法。
save()
使用模型的save()方法来更新数据,会触发写入前、更新前、更新后、写入后事件。
delete()
如果是使用模型方法查询出来数据,然后再删除数据,则会触发删除前、删除后事件。
如果是直接使用条件删除,则不会触发模型事件。因为直接使用条件删除,这时候的delete()方法不是模型方法。
find()
该查询方法会触发查询后事件
destroy()
该删除数据方法会触发查询后、删除前、删除后。所以,该方法是先查询出数据,然后再删除该数据。
restore()
该软删除恢复方法会触发恢复前、恢复后方法
 
                    
                     
                    
                 
                    
                

 
                
            
         
         浙公网安备 33010602011771号
浙公网安备 33010602011771号