发布于 1970-01-01 08:00
  • 3 个回答
    • 看下面截图里面的(是一个下拉框)

      2022-12-01 20:58 回答
    • 这是代码过长不方便阅读的线 可以去掉

      2022-12-01 20:58 回答
      1. 配置的截图有人贴了我就不贴了

      2. 关于PSR的相关规定在这里

      一句话说就是每行的长度无论多长都不应该出错,但建议每行长度不超过80,检查器应当在长度超过120的时候报warning

      1. XXX ? true : false实在啰嗦,!!XXX是转换为true/false的更短的写法,而题主的实例中表达式本身已经是and出来了,连!!都不需要,如果是我的话大概会写成
      phpreturn $this->UserId = session('UserId'))
          && self::isUserId($this->UserId)
          && ($this->UserName = session('UserName')
          && !empty($this->UserName);
      

      等等!

      分完行我才发现,在一串and里面竟然藏了赋值,叫check的函数竟然有副作用,这都是坑队友的行为啊

      phppublic function tryLoginBySession()
      {
          $id = session('UserId');
          $name = session('UserName');
      
          if (!self::isUserId($id) || empty($name)) {
              return false;
          }
      
          $this->UserId = $id;
          $this->UserName = $name;
      
          return true;
      }
      

      a. 有副作用的方法就用动词词组,而非is check 之类的状态判断的方法名
      b. 赋值就只赋值,判断就只判断,不要一边判断一遍赋值,比如说session里有ID但是self::isUserId失败的时候,这个方法返回false表示没登录,但 $this->UserId 竟然有值了,这是定时炸弹

      最后才看到截图里后面那个方法也有? true : false,还是赶紧去掉吧

      2022-12-01 20:58 回答
    撰写答案
    今天,你开发时遇到什么问题呢?
    立即提问
    PHP1.CN | 中国最专业的PHP中文社区 | PNG素材下载 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
    Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有