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

2025-05-29 0 104

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

?

1

2

3

4

5

6

7

8

9

10
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看看这里是怎么实现左侧菜单选中这一困扰众多同学的问题。

?

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18
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方法即可

?

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41
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

?

1

2

3

4

5
use backend\\components\\Menu;

echo Menu::widget([

'options' => ['class' => 'sidebar-menu'],

'items' => MenuHelper::getAssignedMenu(Yii::$app->user->id, null, $callback),

]);

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

收藏 (0) 打赏

感谢您的支持,我会继续努力的!

打开微信/支付宝扫一扫,即可进行扫码打赏哦,分享从这里开始,精彩与您同在
点赞 (0)

声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。

快网idc优惠网 建站教程 解决yii2左侧菜单子级无法高亮问题的方法 https://www.kuaiidc.com/98296.html

相关文章

发表评论
暂无评论