如果陈述和PSR-2很长

时间:2013-02-19 14:40:46

标签: php coding-style

我准备将一些代码迁移到PSR-2标准。在我的代码中,我有if语句多行作为表达式:

if (    $field->getBlockMode() == FieldInterface::BLOCK_MODE_HIDEVAR &&
        !isset($this->enabledBlocks[$field->getBlock()])
) {

}

编写此类表达式的最佳做法是什么?

2 个答案:

答案 0 :(得分:17)

如何使它成为单行代码以避免该问题并使语句更具可读性:

$blockModeIsHidevar = $field->getBlockMode() == FieldInterface::BLOCK_MODE_HIDEVAR;
$blockNotEnabled = !isset($this->enabledBlocks[$field->getBlock()]);

if ($blockModeIsHidevar && $blockNotEnabled) {

}

<强>替代:

我通常用方法来做,这个可以像这样说:

if ($this->blockModeIsHidevar($field) && $this->blockNotEnabled($field)) {

}
// ...
private function blockModeIsHidevar($field)
{
    return $field->getBlockMode() == FieldInterface::BLOCK_MODE_HIDEVAR
}
private function blockNotEnabled($field)
{
    return !isset($this->enabledBlocks[$field->getBlock()])
}

这样,&&的优化仍然会发生。

答案 1 :(得分:4)

首先将其提取为较短的布尔表达式,然后在if()语句中使用这些变量。

即:

$hideVarMode = $field->getBlockMode() === FieldInterface::BLOCK_MODE_HIDEVAR;
$enabledBlock = !isset($this->enabledBlocks[$field->getBlock()];
if($hideVarMode && $enabledBlock) {
    ....
}

(注意,我也把你的第一次测试变成三等分,因为这可能会更好;如果这对你不起作用,请随时改回来)