解决yii2左侧菜单子级无法高亮问题的方法


Posted in PHP onMay 08, 2016

我们先来看看具体问题。
添加角色是属于角色这个菜单的,如何在执行添加角色这个操作时让角色这个菜单处于选中状态呢?
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),
]);

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

PHP 相关文章推荐
DedeCms模板安装/制作概述
Mar 11 PHP
Youku 视频绝对地址获取的方法详解
Jun 26 PHP
PHP $_FILES中error返回值详解
Jan 30 PHP
destoon实现底部添加你是第几位访问者的方法
Jul 15 PHP
Laravel+jQuery实现AJAX分页效果
Sep 14 PHP
PHP构造函数与析构函数用法示例
Sep 28 PHP
php读取和保存base64编码的图片内容
Apr 22 PHP
thinkphp3.2.0 setInc方法 源码全面解析
Jan 29 PHP
PHP 数组黑名单/白名单实例代码详解
Jun 04 PHP
PHP如何将图片文件上传到另外一台服务器上
Aug 26 PHP
php use和include区别总结
Oct 13 PHP
phpmyadmin在宝塔面板里进不去的解决方案
Jul 06 PHP
php面向对象编程self和static的区别
May 08 #PHP
Laravel与CI框架中截取字符串函数
May 08 #PHP
PHP框架性能测试报告
May 08 #PHP
Thinkphp单字母函数使用指南
May 08 #PHP
CentOS下搭建PHP环境与WordPress博客程序的全流程总结
May 07 #PHP
PHP+Ajax+JS实现多图上传
May 07 #PHP
php实现图片上传、剪切功能
May 07 #PHP
You might like
PHP实现MySQL更新记录的代码
2008/06/07 PHP
利用discuz实现PHP大文件上传应用实例代码
2008/11/14 PHP
php 删除记录实现代码
2009/03/12 PHP
JQuery 风格的HTML文本转义
2009/07/01 Javascript
jquery中选择块并改变属性值的方法
2013/07/31 Javascript
JavaScript实现url地址自动检测并添加URL链接示例代码
2013/11/12 Javascript
2014年最火的Node.JS后端框架推荐
2014/10/27 Javascript
jQuery中:only-child选择器用法实例
2015/01/03 Javascript
JS实现的4种数字千位符格式化方法分享
2015/03/02 Javascript
jquery插件hiAlert实现网页对话框美化
2015/05/03 Javascript
jQuery实现仿美橙互联两级导航菜单效果完整实例
2015/09/17 Javascript
javascript原生ajax写法分享
2016/04/10 Javascript
JavaScript实现九九乘法表的简单实例
2016/06/07 Javascript
Bootstrap学习系列之使用 Bootstrap Typeahead 组件实现百度下拉效果
2016/07/07 Javascript
新入门node.js必须要知道的概念(必看篇)
2016/08/10 Javascript
JavaScript实现经典排序算法之选择排序
2016/12/28 Javascript
学习使用jQuery表单验证插件和日历插件
2017/02/13 Javascript
jQuery制作全屏宽度固定高度轮播图(实例讲解)
2017/07/08 jQuery
Vue 项目分环境打包的方法示例
2018/08/03 Javascript
element-ui的回调函数Events的用法详解
2018/10/16 Javascript
详解基于electron制作一个node压缩图片的桌面应用
2019/01/29 Javascript
前端vue-cli项目中使用img图片和background背景图的几种方法
2019/11/13 Javascript
python在不同层级目录import模块的方法
2016/01/31 Python
使用Python为中秋节绘制一块美味的月饼
2019/09/11 Python
记录一下scrapy中settings的一些配置小结
2020/09/28 Python
python IP地址转整数
2020/11/20 Python
解决margin 外边距合并问题
2019/07/03 HTML / CSS
CSS3实现歌词进度文字颜色填充变化动态效果的思路详解
2020/06/02 HTML / CSS
html5+css3气泡组件的实现
2014/11/21 HTML / CSS
HTML块级标签汇总(小篇)
2016/07/13 HTML / CSS
英国领先的票务代理商之一:The Ticket Factory
2019/02/09 全球购物
期中考试后的感想
2015/08/07 职场文书
电力企业职工培训心得体会
2016/01/11 职场文书
家庭教育培训学习心得体会
2016/01/14 职场文书
MySQL查询学习之基础查询操作
2021/05/08 MySQL
36个正则表达式(开发效率提高80%)
2021/11/17 Javascript