200字范文,内容丰富有趣,生活中的好帮手!
200字范文 > json+jQuery实现的无限级树形菜单效果代码【jquery】

json+jQuery实现的无限级树形菜单效果代码【jquery】

时间:2019-03-15 00:33:06

相关推荐

json+jQuery实现的无限级树形菜单效果代码【jquery】

web前端|js教程

json,jQuery,无限级,树形菜单

web前端-js教程

本文实例讲述了json+jQuery实现的无限级树形菜单效果代码。分享给大家供大家参考。具体如下:

网页电子签名源码,ubuntu如何追加目录,爬虫怎么分析数据,php 签到软件,seo电商圈lzw

这里演示json树形菜单,JS无级树树形菜单,引入了jQuery插件,使用递归实现获取无级树数据并生成DOM结构,可以在JSON数据里 扩展无限级 看结构就明白。

负载均衡源码,ubuntu1404源,偏心爬虫怎样制作,php配置php.ini,1688 seo优化lzw

先来看看运行效果截图:

定位算法c源码,vscode开发ph,ubuntu 科大,tomcat编码修改,c 将sqlite数据显示,微信营销插件 关注参加活动,js前端ui框架排行榜,python 爬虫 登陆后搜索,php 开发oa,青海seo优化网,网站备案资料,php网页斗源码,广告flash模板lzw

在线演示地址如下:

/js//jquery-json-tree-style-menu-codes/

具体代码如下:

JS无级树树形菜单.menuTree{ margin-left:-30px;}.menuTree div{ padding-left:30px;}.menuTree div ul{ overflow:hidden; display:none; height:auto;}.menuTree span{ display:block; height:25px; line-height:25px; padding-left:5px; margin:1px 0; cursor:pointer; border-bottom:1px solid #CCC;}.menuTree span:hover{ background-color:#e6e6e6; color:#cf0404;}.menuTree a{ color:#333; text-decoration:none;}.menuTree a:hover{ color:#06F;}.btn{ height:30px; margin-top:10px; border-bottom:1px solid #CCC;}

var json = [{"name":"*a","list":[ {"name":"**a","url":"#a1"}, {"name":"**aa","list":[ {"name":"***a","url":"#a11"}, {"name":"***aa","list":[ {"name":"****a","url":"#a111"}, {"name":"****aa","list":[ {"name":"*****a","url":"#a1111"}, {"name":"*****aa","url":"#a1112"} ]} ]}, {"name":"***aaa","url":"#a13"}, {"name":"***aaaa","url":"#a14"} ] }, {"name":"**a","url":"#a3"} ] }, {"name":"*b","list":[ {"name":"**b","url":"#b1"}, {"name":"**bb","list":[ {"name":"****b","url":"#b111"}, {"name":"****bb","url":"#b112"} ] }, ] }, {"name":"*c","list":[ {"name":"**c","url":"#c1"}, {"name":"**cc","url":"#c2"} ] }, {"name":"*d"} ]/*递归实现获取无级树数据并生成DOM结构*/var str = "";var forTree = function(o){ for(var i=0;i<o.length;i++){ var urlstr = ""; try{ if(typeof o[i]["url"] == "undefined"){ urlstr = "

"+ o[i]["name"] +""; }else{ urlstr = "

"+ o[i]["name"] +""; } str += urlstr; if(o[i]["list"] != null){ forTree(o[i]["list"]); } str += "

"; }catch(e){} } return str;}/*添加无级树*/document.getElementById("menuTree").innerHTML = forTree(json);/*树形菜单*/var menuTree = function(){ //给有子对象的元素加[+-] $("#menuTree ul").each(function(index, element) { var ulContent = $(element).html(); var spanContent = $(element).siblings("span").html(); if(ulContent){ $(element).siblings("span").html("[+] " + spanContent) } }); $("#menuTree").find("div span").click(function(){ var ul = $(this).siblings("ul"); var spanStr = $(this).html(); var spanContent = spanStr.substr(3,spanStr.length); if(ul.find("div").html() != null){ if(ul.css("display") == "none"){ ul.show(300); $(this).html("[-] " + spanContent); }else{ ul.hide(300); $(this).html("[+] " + spanContent); } } })}()/*展开*/$("#btn_open").click(function(){ $("#menuTree ul").show(300); curzt("-");})/*收缩*/$("#btn_close").click(function(){ $("#menuTree ul").hide(300); curzt("+");})function curzt(v){ $("#menuTree span").each(function(index, element) { var ul = $(this).siblings("ul"); var spanStr = $(this).html(); var spanContent = spanStr.substr(3,spanStr.length); if(ul.find("div").html() != null){ $(this).html("["+ v +"] " + spanContent); } }); }

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。