如何让你的代码不变成屎山
小明是一名萌新php程序员,受雇在一家传统的企业crm开发。
一天老板提出一个新的需求
业务部的业务员下了一张订单的时候,需要钉钉消息提醒物流部的同事去处理
小明收到需求,然后打开了下单的model代码如下
<?php
class Order {
public function create($params)
{
if (user == '业务员') {
//todo 查询商品
//todo 计算价格
//todo 插入数据库
......
}
}
}
然后小明很快就完成了老板的需求
<?php
class Order {
public function create($params)
{
if (user == '业务员') {
//todo 查询商品
//todo 计算价格
//todo 插入数据库
......
//todo 发送钉钉消息给物流部同事
}
}
}
这一段代码就这样,每次新增需求都不挺的网里面加逻辑,最后变成了一堆屎山。完全部分能复用
现在我们来分析这段代码的问题
一. 违反了单一原则,再一个方法里做了n件事情
这个方法里做了几件事情
- 权限检查
- 发送消息
- 插入数据库
- …….
这样做的坏处就是以后如果我要给运营权限去添加订单时候,这里就需要添加if else 然后越来越多的if else 代码就更难维护了
二. 把权限验证放在model层
权限验证我们应该放在路由访问前后或者控制器里,这样当我们复用该代码时候就不用担心权限问题了
三. 把所有业务逻辑全放在model层
model层应该是一栋建筑的地基,功能应该尽量简单且一旦完成了就不轻易改动的,如果有新的需求我们应该新增方法,而不提倡修改原来的代码。这样既不破坏原来的代码,也能更方便的拓展新功能。
以上是本人在写代码过程中感悟,我仅一家之言,有不对的地方欢迎指正。