我想为菜单项添加条件,因此当用户登录时,他会看到菜单,具体取决于他的user_type
。这是我的代码。
Nav::widget([
'encodeLabels' => false,
'options' => ['class' => 'sidebar-menu'],
'items' => [
// I want to insert condition here
[
'label' => '<span class="fa fa-fw fa-globe"></span> Menu1',
'url' => ['/menu1'],
],
[
'label' => '<span class="fa fa-fw fa-list-alt"></span> Menu2',
'url' => ['/menu2'],
],
]);
有些用户可以访问menu1
,其他用户只能访问menu2
。
答案 0 :(得分:5)
1)对于单项使用visible
属性(信息可用here):
[
'label' => '<span class="fa fa-fw fa-globe"></span> Menu1',
'url' => ['/menu1'],
'visible' => $condition,
],
2)作为替代方案,您可以在渲染窗口小部件之前构建数组,并有条件地包含/排除某些依赖于条件的数组项。
$items = [];
if ($condition) {
$items[] = ...
} else {
...
}
echo Nav::widget([
'items' => $items,
]);
例如,请参阅advanced template frontend layout中如何形成菜单项。
答案 1 :(得分:1)
我通过使用自己的访问检查功能扩展Nav类来做类似的事情。
class AccessNav extends Nav
{
public function renderItem($item)
{
$url = ArrayHelper::getValue($item, 'url', '#');
if( PermissionManager::checkAccessByUrl($url))
{
return parent::renderItem($item);
}
}
}