无论如何我可以清理
if($class == 2 AND $posts >=1){$showpost ="1";} else {$showpost ="$posts";
if($class == 3 AND $posts >=2){$showpost ="2";} else {$showpost ="$posts";
if($class == 4 AND $posts >=3){$showpost ="3";} else {$showpost ="$posts";
if($class == 5 AND $posts >=4){$showpost ="4";} else {$showpost ="$posts";
if($class == 6 AND $posts >=5){$showpost ="5";} else {$showpost ="$posts";
if($class == 7 AND $posts >=6){$showpost ="6";} else {$showpost ="$posts";
}}}}}}
我最后不想要}}}}}}。
答案 0 :(得分:7)
if (($class >= 2) && ($class <= 7) && ($posts >= $class - 1))
$showpost = $class - 1;
else
$showpost = $posts;
if
分为两部分:
if (
($class >= 2) && ($class <= 7) // Check $class is between 2 and 7 inclusive
&& ($posts >= $class - 1)) // Check $posts >= $class -1
// so if $class is 4 this checks if $posts >= 3
这与原始代码中的逻辑相匹配 - 这只是看模式的问题。
如果你需要$ showpost成为一个字符串(很可能你没有),你可以像这样强制转换为字符串:
$showpost = (string)$showpost;
答案 1 :(得分:5)
您可以删除除最后一个之外的所有$showpost ="$posts";
语句:
if ($class == 2 AND $posts >=1) {
$showpost = "1";
} else if ($class == 3 AND $posts >=2) {
$showpost = "2";
} else if ($class == 4 AND $posts >=3) {
$showpost = "3";
} else if ($class == 5 AND $posts >=4) {
$showpost = "4";
} else if ($class == 6 AND $posts >=5) {
$showpost = "5";
} else if ($class == 7 AND $posts >=6) {
$showpost = "6";
} else {
$showpost ="$posts";
}
甚至可以总结一下:
if ($class >= 2 && $class <= 7 && $posts >= ($class - 1)) {
$showposts = $class - 1;
} else {
$showposts = $posts;
}
答案 2 :(得分:2)
你可以使用它,不是很好,但会起作用。
if($posts >= ($class - 1) AND $class >= 2 AND $class < 8) { $showpost = $class - 1; }
else { $showpost = $posts; }
答案 3 :(得分:0)
制作Karnaugh map。当它真正有意义时,不要避免“切换”。