PHP 编码规范,这里该不该断行?

发布于 2022-08-30 16:41:13 字数 476 浏览 27 评论 0

phpStorm中自动的一个代码格式化规范。来自PSR01,“?”问号这里是否真的需要断行?
如何配置phpStorm去掉这个断行

//检测是否在SESSION 中
public function inSessionCheck()
{
    return ($this->UserId = session('UserId')) && self::isUserId($this->UserId) && ($this->UserName = session('UserName') && !empty($this->UserName))
        ? true : false;
}

图片描述

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(3

梦幻的心爱 2022-09-06 16:41:13
  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-09-06 16:41:13

看下面截图里面的(是一个下拉框)
图片描述

第七度阳光i 2022-09-06 16:41:13

这是代码过长不方便阅读的线 可以去掉

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文