zoukankan      html  css  js  c++  java
  • 如何让你的代码不变成屎山

    小明是一名萌新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件事情

    这个方法里做了几件事情

    1. 权限检查
    2. 发送消息
    3. 插入数据库
    4. .......

    这样做的坏处就是以后如果我要给运营权限去添加订单时候,这里就需要添加if else 然后越来越多的if else 代码就更难维护了

    二. 把权限验证放在model层

    权限验证我们应该放在路由访问前后或者控制器里,这样当我们复用该代码时候就不用担心权限问题了

    三. 把所有业务逻辑全放在model层

    model层应该是一栋建筑的地基,功能应该尽量简单且一旦完成了就不轻易改动的,如果有新的需求我们应该新增方法,而不提倡修改原来的代码。这样既不破坏原来的代码,也能更方便的拓展新功能。

    以上是本人在写代码过程中感悟,我仅一家之言,有不对的地方欢迎指正。

  • 相关阅读:
    数组方法之find
    检查数组中是否有NaN
    数组方法之includes
    数组方法之lastIndexOf
    数组方法之indexOf
    数组方法之forEach
    col-md-push-*和col-md-offset的区别
    35个jQuery小技巧!
    35个jQuery小技巧!
    VS 2013插件
  • 原文地址:https://www.cnblogs.com/echoou/p/15216535.html
Copyright © 2011-2022 走看看