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

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

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

相关文章推荐

css页面左中右分栏布局两种方式示例代码

css页面左中右分栏布局两种方式示例代码

bootstrap treeview实现target功能,iframe中打开页面

既然是treeview是侧栏,那么肯定都是用target=iframename这种连接方式,在右边的iframe中打开页面啊,可惜这个插件没这个属性。 作者说用这个nodeSelected解决。 ...

js实现页面跳转菜单选中

KeepAccounts/initializeShiftMahjong"> images/iconfont-j...

WPF使用菜单实现页面跳转

1、Menu的使用 1.1 MenuData.xml文件 1.2 前台代码

js实现页面跳转的几种方式

  • 2007年11月20日 22:18
  • 532B
  • 下载

JAVA和MySQL实现分页和页面跳转指定当前显示页数的问题

首先,分页需要JDBC基础。所以分页也没什么好说的,主要是分页算法。直接扔出代码 String sql2 = "select * from job limit ?,? "; ps = co...

往下拖动页面滚动条时,固定住菜单栏(不随其他内容网上滚动,兼容各版本IE、Chrome、Firefox)

// 定义菜单栏离页面顶部的距离,默认为200 var divOffsetTop = 200; //滚动事件 window.onscroll=function(){ var div ...
  • senton
  • senton
  • 2012年03月12日 08:59
  • 3929

js页面跳转整理

  • 2017年02月23日 13:58
  • 24KB
  • 下载

往下拖动页面滚动条时,固定住菜单栏(不随其他内容网上滚动,兼容各版本IE、Chrome、Firefox)

>   html xmlns="http://www.w3.org/1999/xhtml">     head>       meta http-equiv="Content-Type" con...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:JS巧妙实现多级菜单中当前菜单不随页面跳转样式而发生变化
举报原因:
原因补充:

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