如何让这段代码更高效/动态,所以如果我需要传递更多参数,那么它是动态的?
因为现在在这一点上它有点乱,我喜欢我的代码干净简洁:)
protected function getSettings()
{
$args = func_get_args();
switch (func_num_args()) {
case 1:
$set = (isset($this->settings[ $args[0] ]))
? $this->settings[ $args[0] ]
: array();
break;
case 2:
$set = (isset($this->settings[ $args[0] ][ $args[1] ]))
? $this->settings[ $args[0] ][ $args[1] ]
: array();
break;
case 3:
$set = (isset($this->settings[ $args[0] ][ $args[1] ][ $args[2] ]))
? $this->settings[ $args[0] ][ $args[1] ][ $args[2] ]
: array();
break;
case 4:
$set = (isset($this->settings[ $args[0] ][ $args[1] ][ $args[2] ][ $args[3] ]))
? $this->settings[ $args[0] ][ $args[1] ][ $args[2] ][ $args[3] ]
: array();
break;
case 5:
$set = (isset($this->settings[ $args[0] ][ $args[1] ][ $args[2] ][ $args[3] ][ $args[4] ]))
? $this->settings[ $args[0] ][ $args[1] ][ $args[2] ][ $args[3] ][ $args[4] ]
: array();
break;
default:
$set = $this->settings;
break;
}
return $set;
}
答案 0 :(得分:2)
未经测试,但方法有效
function f() {
$ptr = $this->settings;
foreach (func_get_args() as $arg) {
if (!is_array($ptr) || !is_scalar($arg) || !isset($ptr[$arg])) {
return array();
}
$ptr = $ptr[$arg];
}
return $ptr;
}
我对is_scalar
和is_array
的测试会阻止您使用利用ArrayAccess
,SplObjectStorage
等的对象。我假设你没有。