序言

此前,我看过这样的一个提问“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里面就好。

如果你的系统本来就很小,业务逻辑也超级简单,也不存在长期演进迭代的需求,随你怎么高兴怎么写都行。