java生成树json_递归解析JSON对象并动态生成树

本文介绍了一种方法,通过JavaScript模拟数据,然后利用递归函数`createTree`解析JSON对象,动态生成树状结构。该函数遍历JSON数组,查找指定父ID的子节点,并在HTML中生成相应的`<ul>`和`<li>`元素。最后,通过jQuery添加点击事件来控制菜单的展开和折叠。
无标题文档

body{

font-size:14px;

margin:0;}

div{

width:auto;

height:auto;

line-height:150%;}

ul{

list-style:none;

margin-left:-20px;}

ul li:hover{

background-color:#DDDDDD;

color:#FF0000;

cursor:pointer;}

//模拟数据

var jsonData = [

{"id":"1","name":"父节点1","url":"www.baidu.com","pid":"0"},

{"id":"4","name":"父节点11","url":"","pid":"1"},

{"id":"13","name":"父节点111","url":"","pid":"4"},

{"id":"14","name":"父节点112","url":"","pid":"4"},

{"id":"5","name":"父节点12","url":"","pid":"1"},

{"id":"6","name":"父节点13","url":"","pid":"1"},

{"id":"2","name":"父节点4","url":"","pid":"0"},

{"id":"7","name":"父节点41","url":"","pid":"2"},

{"id":"8","name":"父节点42","url":"","pid":"2"},

{"id":"9","name":"父节点43","url":"","pid":"2"},

{"id":"3","name":"父节点5","url":"","pid":"0"},

{"id":"10","name":"父节点51","url":"","pid":"3"},

{"id":"11","name":"父节点52","url":"","pid":"3"},

{"id":"12","name":"父节点53","url":"","pid":"3"}

] ;

//主方法,运用递归实现

function createTree(jsons,pid){

if(jsons != null){

var ul = '

  • ' ;

for(var i=0;i

if(jsons[i].pid == pid){

ul += '

' + jsons[i].name + "" ;

ul += createTree(jsons,jsons[i].id) ;

}

}

ul += "

" ;

}

return ul ;

}

$(function(){

var ul = createTree(jsonData,0) ;

$("#continer").append(ul) ;

//控制菜单的隐藏显示

$("ul[class] li").each(function(){

$(this).click(function(){

$(this).next().toggle() ;

}) ;

}) ;

}) ;

9890e79b6f1764b55b918930e90fc11c.png

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值