在此代码中是否有一种删除重复的好方法:
if ($design->unit_system=="English")
{
define('LIMIT_AF', '200');
define('LIMIT_BF', '0');
define('LIMIT_CM', '50');
define('LIMIT_DB', '50');
define('LIMIT_FB', '100');
}
else if ($design->unit_system=="Metric")
{
define('LIMIT_AF', convert(200, 'gpm', 'm3h'));
define('LIMIT_BF', convert(0, 'gpm', 'm3h'));
define('LIMIT_CM', convert(50, 'gpm', 'm3h'));
define('LIMIT_DB', convert(50, 'psi', 'bar'));
define('LIMIT_FB', convert(100, 'psi', 'bar'));
}
如果任何努力比现在更复杂,我正在努力。
答案 0 :(得分:2)
这个怎么样 - 根据OP编辑更新:
$constants = array(
'LIMIT_AF' => array(200, 'gpm', 'm3h'),
'LIMIT_BF' => array(0, 'gpm', 'm3h'),
'LIMIT_CM' => array(50, 'gpm', 'm3h'),
'LIMIT_DB' => array(50, 'psi', 'bar'),
'LIMIT_FB' => array(100, 'psi', 'bar'),
);
foreach($constants as $key => $info){
if($design->unit_system=="English"){
define($key, $info[0]);
}elseif($design->unit_system=="Metric"){
define($key, convert($info[0], $info[1], $info[2]));
}
}
答案 1 :(得分:1)
这对我大吼大叫"配置文件"。
或者,您可以将值放在数组中,然后在:
之后处理它们$settings=array('LIMIT_AF'=>200,...);
foreach ($settings as $name=>$value) {
if (design->unit_system=="English") {
define($name,$value);
} else if ($design->unit_system=="Metric") {
define($name,convert($value,'gpm','m3h'));
} else {
## DONT FORGET TO THROW AN EXCEPTION rather than have these undefined!
}
}