一、总结
1、通过模型事件(钩子函数),可以在插入更新删除等前后执行一些特定的功能
2、模型事件是写在模型里面的,控制器中也必须用了模型操作数据库才能触发模型事件
3、模型事件是需要注册的,注册了才能使用,可用init统一注册
4、支持传入一个参数,(当前的模型对象实例),也就是你传到模型中的数据,也就是你传到数据库中的数据
实例:图片上传
模型
<?php
namespace app\admin\model;
use think\Model;
class Article extends Model
{
protected static function init() //用来统一注册,里面的事件注册了才能用
{
Article::event('before_insert', function ($datain) { //支持传入一个参数,(当前的模型对象实例),也就是你传到模型中的数据
if($_FILES['athumb']['tmp_name']){
// 获取表单上传文件 例如上传了001.jpg
$file = request()->file('athumb');
// 移动到框架应用根目录/public/uploads/ 目录下
$info = $file->move(ROOT_PATH . 'public' . DS . 'static/uploads/admin');
// 已经上传成功,我们要把文件的路径写进数据库
$datain['athumb']='/static/uploads/admin/'.$info->getSaveName();
}
});
}
}
控制器:
<?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_delete
、after_delete
、before_write
、after_write
、before_update
、after_update
、before_insert
、after_insert
事件行为
标签位 | 描述 |
---|---|
before_insert | 新增前 |
after_insert | 新增后 |
before_update | 更新前 |
after_update | 更新后 |
before_write | 写入前 |
after_write | 写入后 |
before_delete | 删除前 |
after_delete | 删除后 |
使用方法如下:
<pre style="margin: 0px; padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 10px !important; white-space: pre-wrap; overflow-wrap: break-word; border-left: 4px ridge rgb(0, 255, 153) !important;">User::event('before_insert', function ($user) { if ($user->status != 1) { return false; } });
</pre>
注册的回调方法支持传入一个参数(当前的模型对象实例),并且before_write
、before_insert
、 before_update
、before_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 | 删除后 |
一些博文中有一些参考内容因时间久远找不到来源了没有注明,如果侵权请联系我删除。
作者相关推荐
thinkphp模型事件(钩子函数:模型中在增删改等操作前后自动执行的事件)
thinkphp模型中的获取器和修改器(根据字段名自动调用模型中的方法)
ThinkPHP5.0框架开发--第11章 TP5.0 杂项
ThinkPHP5.0框架开发--第10章 TP5.0验证器