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

解決yii2左側菜單子級無法高亮問題的方法

編輯:PHP綜合

我們先來看看具體問題。
添加角色是屬於角色這個菜單的,如何在執行添加角色這個操作時讓角色這個菜單處於選中狀態呢?
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),
]); 

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

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