所以我有以下代码:
$options = array(
'navigation' => array(
'page_title' => 'test',
'menu_title' => 'test_title',
'capabillity' => '',
'menu_slug' => '',
'function' => '',
'icon_url' => '',
'position' => '',
'sub_menues' => array(
array(
'page_title' => 'test',
'menu_title' => 'test_title',
'menu_slug' => 'bla'
),
array(
'page_title' => 'apples',
'menu_title' => 'test_apples',
), // Set of Navigations
)
),
'settings' => array(
array(
'option_group' => 'bla',
'option_name' => '',
'sanitize_call_back' => ''
)
),
'core_template' => 'path/to/admin/template.phtml'
);
foreach($options as $setting=>$option){
if($setting == 'navigation' && is_array($option)){
foreach($option as $k=>$v){
if(is_array($v)){
foreach($v as $sub_menu){
foreach($sub_menu as $sk=>$sv){
if(isset($sub_menu[$sk])){
echo $sub_menu['menu_slug'];
}
}
}
}
if(isset($option[$k])){
echo $option['page_title'];
}
}
}
if($setting == 'settings' && is_array($option)){
foreach($option as $settings_options){
foreach($settings_options as $sk => $sv){
if(isset($settings_options[$sk])){
echo $settings_options['option_group'];
}
}
}
}
if($setting = 'core_template'){
echo $options['core_template'];
}
}
是的,这是一个混乱的问题,需要重构,直到你抛出一个不存在的变量。一个很好的方法:
echo $sub_menu['menu_slug'];
现在menuslug存在于navigation/submenues/[0]数组中,但不存在于[1]数组中。
解决此问题的典型方法是:
if(isset($sub_menu['menu_slug'])){ // do something }
正如你从导航阵列中看到的那样,如果设置了这样做,那么就会有很多我正在寻找一种更干净、更整洁的方法,我可以只做$sub_menu[‘something’],它会自动检查是否存在,如果存在,则返回其值,如果不做任何事情,则忽略它。
现在我有了正确的想法,如果设置为$sub_menu[$sk]*,我可以在哪里做:
echo $sub_menu[$sk];
问题是,我在这里调用一个接受参数的函数,参数是键的值,因此我必须执行$sub_menu['enu_slug']。
所以我的问题是:
我该怎么做:
some_function_call($sub_menu['menu_slug']);
无需做:
if(isset($sub_menu['menu_slug']) && isset($sub_menu['page_title']) /*...and so on...*/){
some_function_call($sub_menu['menu_slug'], $sub_menu['page_title'] /*..and so on...*/);
}
捕获-一些选项,例如(例如)菜单段塞,可能是可选的。
有什么想法吗?
好吧,如果你的密钥对所有级别都是唯一的,你可以这样做:
array_walk_recursive($options, function($value, $key){
if($value && in_array($key, array('menu_slug', 'page_title', 'option_group', 'core_template')))
print $value;
});
:)
但我认为您的真正目的是用HTML字符串包装此文本,因此您应该使用switch
而不是我的if
语句,并打印您想要的任何内容。如果需要按特定顺序打印内容,请使用临时数组来存储生成的输出,并在完成后打印。