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

WBOY
發布: 2016-07-29 08:50:43
原創
956 人瀏覽過

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

use mdm\admin\components\MenuHelper; 
<&#63;php 
$callback = function($menu){ 
 //鉴于篇幅有限,这里的代码省略,源码见于原文
}; 
//这里我们对一开始写的菜单menu进行了优化
echo dmstr\widgets\Menu::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

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

大功告成,現在我們左側的選單所引用的Menu

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

以上就介紹了解決yii2左側選單子級無法高亮問題的方法,包括了yii,的方法方面的內容,希望對PHP教程有興趣的朋友有所幫助。

相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板