序言
此前,我看过这样的一个提问“Yii2框架中,有必要再分离service层么?”,从别人的回答中,自己也收获了答案,但我觉得还需要有个活生生的粟子,才具有更加清晰明了和强有力的说服力。如对我的实战经历感兴趣的继续往下看,喜欢的还可以点击推荐和收藏。在举粟子前,我先讲讲service是什么?有什么作用吧?免得还有人糊涂。
1、service是什么?
在面向OO的系统里,service就是biz manager,在面向过程的系统里service就是TS脚本。
2、service有什么作用?
service层的作用就是把这些需要多个model参与的复杂业务逻辑单独封装出来,这些model之间不再发生直接的依赖,而是在service层内协同完成逻辑。service层的第一个目的其实就是对model层进行解耦。
需求分析
1、在Yii2框架中建立service层,专门处理公共且复杂的业务逻辑。
效果图
1、在common下建立个service层。
2、部分公共数据处理逻辑(主要的数据处理都写在这里)。
代码分析
1、在commonservice下写个CluesBranchService.php文件,CluesBranchService类继承本模块主要的models类Chance。凡是关于Chance的公共业务逻辑都往这个文件里写。
namespace common\service;
use Yii;
use api\modules\v1\models\Sales;
use api\modules\v1\chance\models\Chance;
/**
* //下属的线索公共数据处理逻辑
*/
class CluesBranchService extends Chance
{
//下属的线索列表
public static function getIndex()
{
$SalesModel = new Sales();
$uids = $SalesModel->sevenChild(Yii::$app->user->id);
if(count($uids)){
$query = Chance::find()->where(['in','owner_id',$uids]);
}else{
$query = Chance::find()->where(['owner_id'=>'-1']);
}
return $query;
}
}
2、Controllers里调用。
use common\service\CluesBranchService;
$query = CluesBranchService::getIndex();
注释:这里返回的是$query,而不是查询的结果,用过Yii2的都知道列表实现分页用的是ActiveDataProvider,不需要查出结果,为了统一起来所以这里直接返回$query。如有特殊需要加where、andWhere或者获取数据结果的可以这样$query->where(['条件']);$query->all()。
分析总结
以上是一个业务逻辑比较简单的service层的实现方式,看到这里可能还有人疑惑,到底应不应该分离service层?
简单粗暴的总结来说,如果你的某个业务逻辑,需要用到多个model,就放到service层里面去,如果只是这个model自己的事,跟其它的model没有任何关系,放到model里面就好。
如果你的系统本来就很小,业务逻辑也超级简单,也不存在长期演进迭代的需求,随你怎么高兴怎么写都行。