项目中,遇到这样的场景: 需要把用户提交的数据保存到 look 表,同时表单中的 add_img 图片地址数组,分别保存到 lookmeida 表。 这个多出来的,保存图片的功能,不需要改动控制器的代码,借助 Model 的 afterSave 生命周期函数,就可以自动帮我们完成。原理是look表的记录保存(或者修改)之后,会产生一个 lookid ,然后我们将这个lookid 和 mediaurl 存储到 lookmedia表中去。 上代码吧,打字说不清楚
public function afterSave($insert,$changedAttributes)
{
if (Yii::$app->id=='app-backend'){
//保存图片字段
$add_imgarr=$this->add_img;
if ($add_imgarr){
foreach (array_filter($add_imgarr) as $mediaurl){
$lookmedia=new Lookmedia();
$lookmedia->lookid=$this->lookid;
$lookmedia->mediaurl=$mediaurl;
$lookmedia->type=0;
$lookmedia->save();
}
}
}
if (parent::afterSave($insert,$changedAttributes)) {
return true;
}else return false;
}
这里只提三点,也算是几个坑吧: 1)afterSave 的参数,$insert 和 $changedAttributes 是固定写法,必须要有,否则报错。 2)函数内部,在本地环境中,我之前写的是 beforeSave 无报错,程序运行正常;但移植到服务器上之后,会报错,于是改为 afterSave 后正常。 3)实测,我们新增的逻辑,必须放在 parent 函数之外,否则不会被执行(图片已经上传,但是lookmedia表中没有记录)