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用于删除并返回数组的最后一个元素,此步很重要。

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

版权声明:本文为博主原创文章,未经博主允许不得转载。

使用动态JavaScript实现多级菜单联动时不刷新页面的方法

问题的提出:如下图所示,需要使用多级菜单输入地址,具体有以下要求:(1)    当选中某一级列表项时才能出现该项对应的下一级列表供用户选择。比如在省级区域选中“湖北省”时,市级区域里边只能出现湖北省的...
  • bookdog
  • bookdog
  • 2004年11月02日 19:21
  • 3161

HTML5 History对象,Javascript修改地址栏而不刷新页面

HTML5 History对象,Javascript修改地址栏而不刷新页面 一、History对象 History 对象包含用户(在浏览器窗口中)访问过的 URL。 Histor...
  • p312011150
  • p312011150
  • 2017年06月20日 14:16
  • 937

7句js代码实现网页 折叠菜单

最近经常用到javascript,做了很多网页效果,其中有个折叠菜单。 网上的代码 一大堆,麻烦,而且看不懂,我就搞不懂了,写那么多代码干嘛~~~~ 所以自己写了个。 主要用到了 jquery和u...
  • u010402518
  • u010402518
  • 2013年05月08日 22:13
  • 7126

js多级菜单样式

-----------------------------------------------------------------------index.html http://www.w3.org...
  • fengxinzi_jing
  • fengxinzi_jing
  • 2013年03月15日 16:27
  • 1435

JS-网页中分页栏

最近在写网页,用JS手写了一个分页栏 效果html代码 «
  • qhshiniba
  • qhshiniba
  • 2015年12月19日 16:26
  • 2724

css+html+js实现下拉及多级弹出菜单

本文将使用css+html+js实现横向菜单,具有下拉的多级弹出菜单。 首先我们来看看效果图: 首先应该写html部分的代码,代码比较简单,代码如下: ...
  • wj903829182
  • wj903829182
  • 2014年08月23日 08:48
  • 3975

三种方式实现网页二级菜单

方法一:使用HTML和CSS实现 首先是Html代码,习惯上会将菜单放在一个div里,使用盒子模型,方便以后的操作和设置样式。 二级菜单也就是在一级菜单中的li中再添加一个ul-li结构 ...
  • Bazingaea
  • Bazingaea
  • 2016年11月28日 21:18
  • 14110

微信公众号开发--自定义菜单跳转页面并获取用户信息(续)

自定义菜单获取用户信息详细介绍以及苹果设备的空指针异常处理
  • frankcheng5143
  • frankcheng5143
  • 2016年10月19日 14:06
  • 13607

jquery 给当前页面或者跳转后页面对应的导航栏添加选中样式

用jquery js 给当前页面或者跳转后页面对应的导航栏添加选中样式是项目中很常见的的效果,几乎每个网站都会用到, 这里有两种效果,一种是直接给当前页面对应的导航栏添加样式,当页面刷新或者跳转页面...
  • shi851051279
  • shi851051279
  • 2016年10月21日 16:45
  • 1523

页面局部刷新(左侧菜单变化,右边div内容变化)

页面局部刷新 jquery  load 一:全局页面:menu.html(jsp) 1.     引入js scripttype="text/javascript"src="js/jquery...
  • washli2001
  • washli2001
  • 2013年05月06日 16:14
  • 5469
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:JS巧妙实现多级菜单中当前菜单不随页面跳转样式而发生变化
举报原因:
原因补充:

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