首页 php教程 php手册 yii2 左侧菜单子级无法高亮的问题 - 白狼栈

yii2 左侧菜单子级无法高亮的问题 - 白狼栈

May 20, 2016 am 10:14 AM

作者:白狼 出处:http://www.manks.top/question/20160508000001.html 本文版权归作者,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利。

前面我们写的文章yii2 rbac权限控制之菜单menu详细教程,很完美,也很实用,鉴于不少小伙伴咨询的问题,这里做一个统一的说明。我们先来看看具体问题。

添加角色是属于角色这个菜单的,如何在执行添加角色这个操作时让角色这个菜单处于选中状态呢?
adminlte左侧导航的Create,View等action不能定位到index的模块(左侧二级导航不能展开定位)
如果你是按照我们上文的教程来的,那接下来所要说明的问题应该不是问题,先来看看我们当时是怎么处理左侧菜单menu的

<span style="color: #0000ff;">use</span><span style="color: #000000;"> mdm\admin\components\MenuHelper; 
</span><span style="color: #000000;">php 
</span><span style="color: #800080;">$callback</span> = <span style="color: #0000ff;">function</span>(<span style="color: #800080;">$menu</span><span style="color: #000000;">){ 
    </span><span style="color: #008000;">//</span><span style="color: #008000;">鉴于篇幅有限,这里的代码省略,源码见于原文</span>
<span style="color: #000000;">}; 
</span><span style="color: #008000;">//</span><span style="color: #008000;">这里我们对一开始写的菜单menu进行了优化</span>
<span style="color: #0000ff;">echo</span> dmstr\widgets\Menu::<span style="color: #000000;">widget( [ 
    </span>'options' => ['class' => 'sidebar-menu'], 
    'items' => MenuHelper::getAssignedMenu(Yii::<span style="color: #800080;">$app</span>->user->id, <span style="color: #0000ff;">null</span>, <span style="color: #800080;">$callback</span>),<span style="color: #000000;"> 
] ); </span>?>
登录后复制

 

看到这里,我们不妨打开文件dmstr\widgets\Menu看看这里是怎么实现左侧菜单选中这一困扰众多同学的问题。

<span style="color: #0000ff;">protected</span> <span style="color: #0000ff;">function</span> isItemActive(<span style="color: #800080;">$item</span><span style="color: #000000;">)
{
    </span><span style="color: #0000ff;">if</span> (<span style="color: #0000ff;">isset</span>(<span style="color: #800080;">$item</span>['url']) && <span style="color: #008080;">is_array</span>(<span style="color: #800080;">$item</span>['url']) && <span style="color: #0000ff;">isset</span>(<span style="color: #800080;">$item</span>['url'][0<span style="color: #000000;">])) {
        </span><span style="color: #008000;">//</span><span style="color: #008000;">......</span>
        <span style="color: #0000ff;">if</span> (<span style="color: #800080;">$arrayRoute</span>[0] !== <span style="color: #800080;">$arrayThisRoute</span>[0<span style="color: #000000;">]) {
            </span><span style="color: #0000ff;">return</span> <span style="color: #0000ff;">false</span><span style="color: #000000;">;
        }
        </span><span style="color: #0000ff;">if</span> (<span style="color: #0000ff;">isset</span>(<span style="color: #800080;">$arrayRoute</span>[1]) && <span style="color: #800080;">$arrayRoute</span>[1] !== <span style="color: #800080;">$arrayThisRoute</span>[1<span style="color: #000000;">]) {
            </span><span style="color: #0000ff;">return</span> <span style="color: #0000ff;">false</span><span style="color: #000000;">;
        }
        </span><span style="color: #0000ff;">if</span> (<span style="color: #0000ff;">isset</span>(<span style="color: #800080;">$arrayRoute</span>[2]) && <span style="color: #800080;">$arrayRoute</span>[2] !== <span style="color: #800080;">$arrayThisRoute</span>[2<span style="color: #000000;">]) {
            </span><span style="color: #0000ff;">return</span> <span style="color: #0000ff;">false</span><span style="color: #000000;">;
        }
        </span><span style="color: #008000;">//</span><span style="color: #008000;">......</span>
        <span style="color: #0000ff;">return</span> <span style="color: #0000ff;">true</span><span style="color: #000000;">;
    }
    </span><span style="color: #0000ff;">return</span> <span style="color: #0000ff;">false</span><span style="color: #000000;">;
}</span>
登录后复制

 

看吧,看上面的代码,也就是说左侧菜单激活的情况是当前路由完全等于菜单路由时菜单才进行激活。

鉴于我们一开始谈到的不少小伙伴疑惑的两个问题,我们这里只需要稍稍调整下代码,判断控制到controller而非action即可,但是源码文件我们又不能修改,怎么办好呢?天热,凉拌。

这里我们拷贝dmstr\widgets\Menu.php文件到backend\components\Menu.php,然后按照下面的方法修改isItemActive方法即可

<span style="color: #0000ff;">protected</span> <span style="color: #0000ff;">function</span> isItemActive(<span style="color: #800080;">$item</span><span style="color: #000000;">)
{
    </span><span style="color: #0000ff;">if</span> (<span style="color: #0000ff;">isset</span>(<span style="color: #800080;">$item</span>['url']) && <span style="color: #008080;">is_array</span>(<span style="color: #800080;">$item</span>['url']) && <span style="color: #0000ff;">isset</span>(<span style="color: #800080;">$item</span>['url'][0<span style="color: #000000;">])) {
        
        </span><span style="color: #008000;">//</span><span style="color: #008000;">......


        //改写了路由的规则,是否高亮判断到controller而非action</span>
        <span style="color: #800080;">$routeCount</span> = <span style="color: #008080;">count</span>(<span style="color: #800080;">$arrayRoute</span><span style="color: #000000;">);
        </span><span style="color: #0000ff;">if</span> (<span style="color: #800080;">$routeCount</span> == 2<span style="color: #000000;">) {
            </span><span style="color: #0000ff;">if</span> (<span style="color: #800080;">$arrayRoute</span>[0] !== <span style="color: #800080;">$arrayThisRoute</span>[0<span style="color: #000000;">]) {
                </span><span style="color: #0000ff;">return</span> <span style="color: #0000ff;">false</span><span style="color: #000000;">;
            }
        } </span><span style="color: #0000ff;">elseif</span> (<span style="color: #800080;">$routeCount</span> == 3<span style="color: #000000;">) {
            </span><span style="color: #0000ff;">if</span> (<span style="color: #800080;">$arrayRoute</span>[0] !== <span style="color: #800080;">$arrayThisRoute</span>[0<span style="color: #000000;">]) {
                </span><span style="color: #0000ff;">return</span> <span style="color: #0000ff;">false</span><span style="color: #000000;">;
            }
            </span><span style="color: #0000ff;">if</span> (<span style="color: #0000ff;">isset</span>(<span style="color: #800080;">$arrayRoute</span>[1]) && <span style="color: #800080;">$arrayRoute</span>[1] !== <span style="color: #800080;">$arrayThisRoute</span>[1<span style="color: #000000;">]) {
                </span><span style="color: #0000ff;">return</span> <span style="color: #0000ff;">false</span><span style="color: #000000;">;
            }
        } </span><span style="color: #0000ff;">else</span><span style="color: #000000;"> {
            </span><span style="color: #0000ff;">return</span> <span style="color: #0000ff;">false</span><span style="color: #000000;">;
        }


        </span><span style="color: #008000;">//</span><span style="color: #008000;"> if ($arrayRoute[0] !== $arrayThisRoute[0]) {
        //     return false;
        // }
        // if (isset($arrayRoute[1]) && $arrayRoute[1] !== $arrayThisRoute[1]) {
        //     return false;
        // }
        // if (isset($arrayRoute[2]) && $arrayRoute[2] !== $arrayThisRoute[2]) {
        //     return false;
        // }
        
        //......</span>
        
        <span style="color: #0000ff;">return</span> <span style="color: #0000ff;">true</span><span style="color: #000000;">;
    }
    </span><span style="color: #0000ff;">return</span> <span style="color: #0000ff;">false</span><span style="color: #000000;">;
}</span>
登录后复制

 

大功告成,现在我们左侧的菜单引用的Menu文件修改其指向到backend\components\Menu

<span style="color: #0000ff;">use</span><span style="color: #000000;"> backend\components\Menu;
</span><span style="color: #0000ff;">echo</span> Menu::<span style="color: #000000;">widget([
    </span>'options' => ['class' => 'sidebar-menu'],
    'items' => MenuHelper::getAssignedMenu(Yii::<span style="color: #800080;">$app</span>->user->id, <span style="color: #0000ff;">null</span>, <span style="color: #800080;">$callback</span>),<span style="color: #000000;">
]); </span>
登录后复制

 

快去试试看我们的问题解决没有吧。

menuyii2

本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

AI Hentai Generator

AI Hentai Generator

免费生成ai无尽的。

热门文章

R.E.P.O.能量晶体解释及其做什么(黄色晶体)
2 周前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳图形设置
2 周前 By 尊渡假赌尊渡假赌尊渡假赌

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)