博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
利用递归实现简单的树结构菜单
阅读量:5104 次
发布时间:2019-06-13

本文共 1274 字,大约阅读时间需要 4 分钟。

 

数据格式:

var data = [  {title: "11111",childs : [    {title:"aaaaa", childs:[      {title: "xg"}    ]},    {title:"bbbbb"}    ]  },  {title: "22222",childs : [    {title:"aaaaa"},    {title:"bbbbb"}    ]  }];

 

递归函数:

function menu(data){  var ul = "
    ";  for(var i = 0; i < data.length; i++){    ul+="
  • "+data[i].title+"";    if(data[i].childs){ul+=argument.callee(data[i].childs);}    ul+="
  • ";  };  ul+="
";  return ul;}

 

调用:

var menu = menu(data);

 

结果:

也可以做成jq插件

var Menu = function(el,opt){  this.el = el;  //this.default = {},       // 插件默认参数,在这里不需要  this.opt = opt;  // this.opt = $.extend({},this.default,opt);     // 插件默认参数和传参合并,在这里不需要};Menu.prototype = {  init: function(){    var opt = this.opt;    var ul = this.create(opt);    this.el.append(ul);},create: function(opt){  var ul = '
    ';  for(var i = 0; i < opt.length; i++){    ul += '
  • '+opt[i].title;    if(opt[i].childred && opt[i].children != 'undefined'){      ul += arguments.callee(opt[i].childred)    }    ul += '
  • ';  };  ul += '
';  return ul;}}$.fn.menu = function(opt){  // 这里的this是指$(select);  var menu = new Menu(this, opt);  return menu.init();}

 

调用: $(select).menu(data);

结果和上面一样

会的人觉得简单,不会的人再简单也不会,这个我也是花了很长时间才写出来。

 

转载于:https://www.cnblogs.com/hyfl847/p/5852341.html

你可能感兴趣的文章
centos 7 redis-4.0.11 主从
查看>>
Java的基本数据类型与转换
查看>>
博弈论 从懵逼到入门 详解
查看>>
永远的动漫,梦想在,就有远方
查看>>
springboot No Identifier specified for entity的解决办法
查看>>
慵懒中长大的人,只会挨生活留下的耳光
查看>>
"远程桌面连接--“发生身份验证错误。要求的函数不受支持
查看>>
【BZOJ1565】 植物大战僵尸
查看>>
视频:"我是设计师"高清完整版Plus拍摄花絮
查看>>
VALSE2019总结(4)-主题报告
查看>>
浅谈 unix, linux, ios, android 区别和联系
查看>>
51nod 1428 活动安排问题 (贪心+优先队列)
查看>>
中国烧鹅系列:利用烧鹅自动执行SD卡上的自定义程序(含视频)
查看>>
Solaris11修改主机名
查看>>
latex for wordpress(一)
查看>>
如何在maven工程中加载oracle驱动
查看>>
Flask 系列之 SQLAlchemy
查看>>
iframe跨域与session失效问题
查看>>
aboutMe
查看>>
【Debug】IAR在线调试时报错,Warning: Stack pointer is setup to incorrect alignmentStack,芯片使用STM32F103ZET6...
查看>>