程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> 網頁編程 >> PHP編程 >> 關於PHP編程 >> yii2 左側菜單子級無法高亮的問題,yii2菜單子

yii2 左側菜單子級無法高亮的問題,yii2菜單子

編輯:關於PHP編程

yii2 左側菜單子級無法高亮的問題,yii2菜單子


作者:白狼 出處:http://www.manks.top/question/20160508000001.html 本文版權歸作者,歡迎轉載,但未經作者同意必須保留此段聲明,且在文章頁面明顯位置給出原文連接,否則保留追究法律責任的權利。

前面我們寫的文章yii2 rbac權限控制之菜單menu詳細教程,很完美,也很實用,鑒於不少小伙伴咨詢的問題,這裡做一個統一的說明。我們先來看看具體問題。

添加角色是屬於角色這個菜單的,如何在執行添加角色這個操作時讓角色這個菜單處於選中狀態呢?
adminlte左側導航的Create,View等action不能定位到index的模塊(左側二級導航不能展開定位)
如果你是按照我們上文的教程來的,那接下來所要說明的問題應該不是問題,先來看看我們當時是怎麼處理左側菜單menu的

use mdm\admin\components\MenuHelper; 
<?php 
$callback = function($menu){ 
    //鑒於篇幅有限,這裡的代碼省略,源碼見於原文
}; 
//這裡我們對一開始寫的菜單menu進行了優化
echo dmstr\widgets\Menu::widget( [ 
    'options' => ['class' => 'sidebar-menu'], 
    'items' => MenuHelper::getAssignedMenu(Yii::$app->user->id, null, $callback), 
] ); ?>

 

看到這裡,我們不妨打開文件dmstr\widgets\Menu看看這裡是怎麼實現左側菜單選中這一困擾眾多同學的問題。

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即可,但是源碼文件我們又不能修改,怎麼辦好呢?天熱,涼拌。

這裡我們拷貝dmstr\widgets\Menu.php文件到backend\components\Menu.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文件修改其指向到backend\components\Menu

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

 

快去試試看我們的問題解決沒有吧。

menuyii2

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved