js用闭包遍历树状数组的方法

 更新时间:2014年03月19日 09:39:19   作者:  
这篇文章主要介绍了js中用闭包遍历树状数组的方法,需要的朋友可以参考下

做公司项目时,要求写一个方法,方法的参数为一个菜单数组集合和一个菜单id,菜单数组的格式为树状json,如下面所示:

复制代码 代码如下:
[{"id":28,"text":"公司信息","children":[

     {"id":1,"text":"公司文化"},

     {"id":2,"text":"招聘计划"},

     {"id":6,"text":"公司新闻","children":[

          {"id":47,"text":"行业新闻"}]},

          {"id":11,"text":"内部新闻","children":[

                         {"id":24,"text":"行政信息"},

                         {"id":27,"text":"高层指示"}]},

          {"id":22,"text":"联系我们"},

          {"id":26,"text":"产品展示","children":[

                         {"id":32,"text":"电力产品"},

                         {"id":33,"text":"配件介绍"}}]

 }] }]

现在给出的菜单id为32,要求找到对应的项,并返回对应的菜单名称,方法是先循环遍历数组,当项的id等于指定的id时,将菜单名称取出,如果不等于则看当前项是否有children,如果children不为空且数量大于0,则遍历children,这时就要用到javascript的闭包,将遍历children的方法放在一个匿名方法中,这样一直在匿名方法中递归自身,当遇到相同名称的id,就跳出循环,然后从主方法中返回得到的菜单名称,代码如下:

复制代码 代码如下:
function getMenuName(menus, id) {
  var name = "" ;
  for (var i = 0; i < menus.length; i++) {
    if (menus[i].id == id) {
      name = menus[i].text;
      break;
    }
    else {
       (function () {
        var m = arguments[0];
        var menuid = arguments[1];
        for (var j = 0; j < m.length; j++) {
          if (m[j].id == menuid) {
            name = m[j].text;
            break;
          }
          else if m[j].children != null && m[j].children.length > 0) {
            arguments.callee(m[j].children, val);//递归匿名方法
          }
        }
      })(menus[i].children, id);
    }
  }
  return name;
}

相关文章

  • JavaScript 双位非运算(~~ 操作符)使用场景实例探索

    JavaScript 双位非运算(~~ 操作符)使用场景实例探索

    本文为大家介绍JavaScript中双位非运算 ~~, ~~ 操作符是一个强大且经常被忽视的特性,它提供了一种快速、简洁的方式来处理数字和执行类型转换,通常可以被用于数学计算和类型转换,我们先了解一下 ~~ 的基本概念和它的一些应用场景
    2024-01-01
  • Three.Js实现颜色自定义变换效果实例

    Three.Js实现颜色自定义变换效果实例

    这篇文章主要给大家介绍了关于Three.Js实现颜色自定义变换效果的相关资料,文中通过实例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2023-02-02
  • 1秒50万字!js实现关键词匹配

    1秒50万字!js实现关键词匹配

    1秒50万字!js实现关键词匹配,快速进行关键字匹配,感兴趣的小伙伴们可以参考一下
    2016-08-08
  • 简单了解微信小程序 e.target与e.currentTarget的不同

    简单了解微信小程序 e.target与e.currentTarget的不同

    这篇文章主要介绍了微信小程序 e.target与e.currentTarget的区别详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2019-09-09
  • 微信小程序控制view隐藏显示的5种方法汇总

    微信小程序控制view隐藏显示的5种方法汇总

    在微信小程序开发时,经常要用到一个控件会根据不同的情况和环境动态显示与隐藏这种情况,下面这篇文章主要给大家介绍了关于微信小程序控制view隐藏显示的5种方法,需要的朋友可以参考下
    2022-04-04
  • 用Javascript判断图片是否存在,不存在则显示默认图片的代码

    用Javascript判断图片是否存在,不存在则显示默认图片的代码

    用Javascript判断图片是否存在,不存在则显示默认图片的代码,需要的朋友可以参考下。
    2007-03-03
  • 一文总结JavaScript中Promise遇到的问题

    一文总结JavaScript中Promise遇到的问题

    Promise 是异步编程的一种解决方案,比传统的解决方案——回调函数和事件——更合理和更强大。本文将总结一下在Promise中容易遇到的一些问题,感兴趣的同学可以参考下
    2023-05-05
  • JavaScript实现首页图片轮播图效果

    JavaScript实现首页图片轮播图效果

    这篇文章主要介绍了JavaScript实现首页图片轮播图效果,文章围绕主题展开详细的内容介绍,具有一定的参考价值,需要的小伙伴可以参考一下
    2022-06-06
  • 扫微信小程序码实现网站登陆实现解析

    扫微信小程序码实现网站登陆实现解析

    这篇文章主要介绍了扫微信小程序码实现网站登陆实现解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2019-08-08
  • 详解ES6数组方法find()、findIndex()的总结

    详解ES6数组方法find()、findIndex()的总结

    这篇文章主要介绍了详解ES6数组方法find()、findIndex()的总结,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-05-05

最新评论