thinkphp模型事件(钩子函数:模型中在增删改等操作前后自动执行的事件)

thinkphp模型事件(钩子函数:模型中在增删改等操作前后自动执行的事件)

一、总结

1、通过模型事件(钩子函数),可以在插入更新删除等前后执行一些特定的功能

2、模型事件是写在模型里面的,控制器中也必须用了模型操作数据库才能触发模型事件

3、模型事件是需要注册的,注册了才能使用,可用init统一注册

4、支持传入一个参数(当前的模型对象实例),也就是你传到模型中的数据,也就是你传到数据库中的数据

 

实例:图片上传

模型:

 1 <?php
 2 namespace app\admin\model;
 3 use think\Model;
 4 
 5 class Article extends Model
 6 {
 7     protected static function init() //用来统一注册,里面的事件注册了才能用
 8     {
 9         Article::event('before_insert', function ($datain) { //支持传入一个参数,(当前的模型对象实例),也就是你传到模型中的数据
10             if($_FILES['athumb']['tmp_name']){
11                 // 获取表单上传文件 例如上传了001.jpg
12                 $file = request()->file('athumb');
13                 // 移动到框架应用根目录/public/uploads/ 目录下
14                 $info = $file->move(ROOT_PATH . 'public' . DS . 'static/uploads/admin');
15                 // 已经上传成功,我们要把文件的路径写进数据库
16                 $datain['athumb']='/static/uploads/admin/'.$info->getSaveName();
17             }
18         });
19     }
20 }    

控制器:

<?php
namespace app\admin\controller;
use think\Controller;

use app\admin\model\Article as ModelArticle;
use app\admin\model\Cate as ModelCate;
use app\admin\controller\Base;

class Article extends Base
{
    public function add(){
        if(request()->isPost()){
            $datain=input('post.');
            $datain['time']=time();
            $modelArticle=new ModelArticle();
            //2、获取传入的文件数据
            /*在模型的事件中处理了*/
            if($modelArticle->save($datain)){ //用了模型,传入的参数就是$datain
                $this->success('添加文章成功!!','article/lst');
            }else{
                $this->error('添加文章失败!!');
            }
            // dump($datain);die;
            return;
        }
        //将栏目信息显示回增加界面
        //catetree方法新增了栏目的level字段
        $modelCate=new ModelCate();
        $data=$modelCate->catetree();
        $this->assign('data',$data);

        return view();
    }
}

 

 

 

二、thinkphp模型事件(钩子函数)

模型事件

版本新增功能
5.0.4增加模型事件注册快捷方法

模型事件是指在进行模型的写入操作的时候触发的操作行为,包括模型的save方法和delete方法。

模型事件只可以在调用模型的方法才能生效,使用查询构造器通过Db类操作是无效的

模型类支持before_deleteafter_deletebefore_writeafter_writebefore_updateafter_updatebefore_insertafter_insert事件行为

标签位描述
before_insert新增前
after_insert新增后
before_update更新前
after_update更新后
before_write写入前
after_write写入后
before_delete删除前
after_delete删除后

使用方法如下:

User::event('before_insert', function ($user) { if ($user->status != 1) { return false; } }); 

注册的回调方法支持传入一个参数(当前的模型对象实例),并且before_writebefore_insert、 before_updatebefore_delete事件方法如果返回false,则不会继续执行。

支持给一个位置注册多个回调方法,例如:

        User::event('before_insert', function ($user) {
            if ($user->status != 1) { return false; } }); // 注册回调到beforeInsert函数 User::event('before_insert', 'beforeInsert'); 

可以在模型类的init方法里面统一注册模型事件,例如:

namespace app\index\model;

use think\Model; class User extends Model { protected static function init() { User::event('before_insert', function ($user) { if ($user->status != 1) { return false; } }); } } 

调用当前模型也可以写入 self::event('before_insert', ...)

快捷注册(V5.0.4+

V5.0.4+版本开始,系统提供了内置的事件注册的快捷方法,你可以用下面的方式替代

namespace app\index\model;

use think\Model; class User extends Model { protected static function init() { User::beforeInsert(function ($user) { if ($user->status != 1) { return false; } }); } } 

这些模型类的快捷方法如下:

标签位描述
beforeInsert新增前
afterInsert新增后
beforeUpdate更新前
afterUpdate更新后
beforeWrite写入前
afterWrite写入后
beforeDelete删除前
afterDelete删除后
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值