• yii2 左侧菜单子级无法高亮的问题


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

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

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

    use mdmadmincomponentsMenuHelper; 
    <?php 
    $callback = function($menu){ 
        //鉴于篇幅有限,这里的代码省略,源码见于原文
    }; 
    //这里我们对一开始写的菜单menu进行了优化
    echo dmstrwidgetsMenu::widget( [ 
        'options' => ['class' => 'sidebar-menu'], 
        'items' => MenuHelper::getAssignedMenu(Yii::$app->user->id, null, $callback), 
    ] ); ?>

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

    protected function isItemActive($item)
    {
        if (isset($item['url']) && is_array($item['url']) && isset($item['url'][0])) {
            //......
            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;
            }
            //......
            return true;
        }
        return false;
    }

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

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

    这里我们拷贝dmstrwidgetsMenu.php文件到backendcomponentsMenu.php,然后按照下面的方法修改isItemActive方法即可

    protected function isItemActive($item)
    {
        if (isset($item['url']) && is_array($item['url']) && isset($item['url'][0])) {
            
            //......
    
    
            //改写了路由的规则,是否高亮判断到controller而非action
            $routeCount = count($arrayRoute);
            if ($routeCount == 2) {
                if ($arrayRoute[0] !== $arrayThisRoute[0]) {
                    return false;
                }
            } elseif ($routeCount == 3) {
                if ($arrayRoute[0] !== $arrayThisRoute[0]) {
                    return false;
                }
                if (isset($arrayRoute[1]) && $arrayRoute[1] !== $arrayThisRoute[1]) {
                    return false;
                }
            } else {
                return false;
            }
    
    
            // 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;
            // }
            
            //......
            
            return true;
        }
        return false;
    }

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

    use backendcomponentsMenu;
    echo Menu::widget([
        'options' => ['class' => 'sidebar-menu'],
        'items' => MenuHelper::getAssignedMenu(Yii::$app->user->id, null, $callback),
    ]); 

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

    menuyii2

  • 相关阅读:
    Hadoop学习笔记1:伪分布式环境搭建
    VMware 下的CentOS6.7 虚拟机与Windows7通信
    CentOS6.7 下安装JDK
    [HDU 1430] 魔板
    数码问题合集
    [light oj 1328] A Gift from the Setter
    [light oj 1013] Love Calculator
    [POJ 1151] Atlantis
    关于12月28日到12月29日
    [HDU 1199] Color the Ball
  • 原文地址:https://www.cnblogs.com/wwolf/p/5471093.html
Copyright © 2020-2023  润新知