JS巧妙实现多级菜单中当前菜单不随页面跳转样式而发生变化

原创 2017年05月29日 00:36:14

一.概述

        本文介绍了JQuery巧妙实现多级菜单中当前菜单不随页面跳转样式发生变化,貌似没看懂啥意思?

看图说话:就是点二级或多级菜单时,父级展开,当前菜单是被选中状态,这下明白了吧?

二.应用场景

         当一个项目使用公共模板文件时(如上图的左侧菜单栏),我们给每个子菜单添加链接时,点击页面跳转样后还是公共模板的样式,这时就需要实现动态加载当前菜单的样式。

三.实现方法

第一种:.通过php传递变量,模板页面通过接收这些变量来实现当前页面的菜单选中与否,父级展开等这些样式

缺点:虽然实现简单,但是每个页面都需要php传递变量,很繁琐,这种方法不推荐,故不再赘述!

第二种:通过比对当前菜单里的a标签的href值与浏览器的url的值,判断a标签里href属性值是属于浏览器url中的一部分,即表示包含该a标签的菜单应该时被选中状态,在将样式赋予该菜单及对应的父级菜单。

四.举个栗子

 <ul class="sidebar-menu">
        <li class="header">主菜单</li>
        <li class="treeview">
          <a href="#">
            <i class="fa fa-users"></i> <span>用户管理</span>
            <span class="pull-right-container">
              <i class="fa fa-angle-left pull-right"></i>
            </span>
          </a>
          <ul class="treeview-menu">
            <li><a href="{{ path('agent') }}"><i class="fa fa-circle-o"></i> 代理商</a></li>
            <li><a href="{{ path('client') }}"><i class="fa fa-circle-o"></i> 委托人</a></li>
            <li><a href="{{ path('cs_staff') }}"><i class="fa fa-circle-o"></i> 客服</a></li>
            <li><a href="{{ path('admin') }}"><i class="fa fa-circle-o"></i> 管理员</a></li>
          </ul>
        </li>
        <li class="treeview">
          <a href="#">
            <i class="fa fa-bicycle"></i> <span>车辆管理</span>
            <span class="pull-right-container">
              <i class="fa fa-angle-left pull-right"></i>
            </span>
          </a>
          <ul class="treeview-menu">
            <li><a href="{{ path('bike') }}"><i class="fa fa-circle-o"></i> 单车</a></li>
          </ul>
        </li>
        <li class="treeview">
          <a href="#">
            <i class="fa fa-fw fa-cny"></i> <span>统计报表</span>
            <span class="pull-right-container">
              <i class="fa fa-angle-left pull-right"></i>
            </span>
          </a>
          <ul class="treeview-menu">
            <li><a href="{{ path('report')}}"><i class="fa fa-circle-o"></i> 单车收益</a></li>
          </ul>
        </li>
      </ul>

注:上述样式是bootstamp的样式

如果当前页面是管理员页,那个给所对应的li添加class="active"的属性,父级ul的样式由style="display: none;"修改为style="display: block;",ul的父级再添加class="active"的属性,即有了图一的效果。

以下是我写的js实现代码,放在公共js文件即可

  var CURRENT_URL = window.location.href.split('?')[0];
  CURRENT_URL_ARR=CURRENT_URL.split("/",6); 
  for (i=0;i<CURRENT_URL_ARR.length ;i++ ){
    TEM_URL = CURRENT_URL_ARR.join(",");
    TEM_URL = TEM_URL.replace(/,/g,"/");
    $('.sidebar-menu').find('a').filter(function () {
      return this.href ==TEM_URL+"/";
    }).parent('li').addClass('active').parent('ul').css("display","block").parent('li').addClass('active');
    CURRENT_URL_ARR.pop();
  }

解释:

第1行:取得当前url?前的地址,去除url参数

alert(CURRENT_URL);

结果为:http://partner.bike.lc/admin/

第2行:把url里按“/”再次分割成字符串数组,后面的6为了精确的找到对应控制器及方法,按需设着

alert(CURRENT_URL_ARR);

结果为:http:,,partner.bike.lc,admin,

第3行:循环匹配url

第4行:再将数组转化为字符串

aert(TEM_URL);

循环得到的结果依次为:

http:,,partner.bike.lc,admin,

http:,,partner.bike.lc,admin

http:,,partner.bike.lc

...

第5行:将上一步字符串转化为URL形式

aert(TEM_URL);

循环得到的结果依次为:

http://partner.bike.lc/admin/

http://partner.bike.lc/admin

http://partner.bike.lc

...

第6-10行:遍历菜单栏里的所有a标签,判断循环里的url是否有等于a标签的href值,如果有加上所需的样式

 注:

this.href得到的是完整的URL地址;

pop用于删除并返回数组的最后一个元素,此步很重要。

好了,不知道大家理解了没有。主要是理解实现思路,样式可根据自身情况调整~

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/leesin2011/article/details/72796283

[HTML] CSS + JS 多级下拉菜单

多级下拉菜单 //显示子菜单里的内容 function displaySubMenu(li) { var...
  • shylx123
  • shylx123
  • 2015-08-22 20:34:42
  • 3607

js多级菜单

  • 2012年12月29日 09:56
  • 8KB
  • 下载

js实现三级菜单的制作

js实现三级菜单的制作
  • Wangdanting123
  • Wangdanting123
  • 2016-05-08 22:46:02
  • 1768

多级选择菜单——数据加载

今天介绍下多级选择菜单的实现,及数据的加载。 一、效果图              很简单的一个功能实现,当我们选择筛选条件的时候,下面会显示相对应的数 据,点击清空筛选条件,会清空已选择的条...
  • hanxintong9
  • hanxintong9
  • 2016-06-12 15:20:34
  • 1485

js多级菜单样式

-----------------------------------------------------------------------index.html http://www.w3.org...
  • fengxinzi_jing
  • fengxinzi_jing
  • 2013-03-15 16:27:08
  • 1501

多级菜单js实现,可无限分级

  • 2009年04月09日 17:06
  • 36KB
  • 下载

最简单的纯js实现点击展开二级菜单功能

虽然,jQuery已经非常好用了,但是实际的开发项目中,还是有很多限制,比如项目组奇葩的要求,不能使用任何插件,当然,也是考虑插件占用资源,毕竟100+KB对与小型项目来说还是非常大的。我最近就遇到做...
  • well2049
  • well2049
  • 2017-05-16 08:39:54
  • 1646

Javascript实现网页上的多级菜单

  • 2008年10月28日 09:09
  • 6KB
  • 下载

Web前端开发实战2:二级下拉式菜单之JS实现

上一篇博文提到了二级下拉式菜单是用HTML和CSS实现的,我们这一篇来用JavaScript脚本实现下拉菜单的显 示和隐藏。使用 JavaScript方法实现我们需要用的知识有:         1)...
  • erlian1992
  • erlian1992
  • 2015-12-31 14:04:46
  • 9959

JS实现多级竖向菜单

  • 2008年12月07日 18:05
  • 2KB
  • 下载
收藏助手
不良信息举报
您举报文章:JS巧妙实现多级菜单中当前菜单不随页面跳转样式而发生变化
举报原因:
原因补充:

(最多只允许输入30个字)