递归渲染树

<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8" />
		<style>
			#aside .aside-content>ul ul{
				display: none;
			}
		</style>
	</head>
	<body>
		<div id="aside" style="padding: 20px;border: 1px solid;">
			<div class="aside-scroll" style="padding: 20px;border: 1px solid;">
				<div class="aside-content" style="padding: 20px;border: 1px solid;">
				</div>
			</div>
		</div>
		<script type="text/javascript" src="js/jquery-2.1.1.min.js" ></script>
		<script>
			
			//也可以单独提取到json文件中,通过get方式ajax读取
			var nodes =[
				{ id:1, pId:0, name:"随意勾选 1"},
				{ id:11, pId:1, name:"随意勾选 1-1"},
				{ id:111, pId:11, name:"随意勾选 1-1-1"},
				{ id:112, pId:11, name:"随意勾选 1-1-2", checked:true},
				{ id:12, pId:1, name:"随意勾选 1-2"},
				{ id:121, pId:12, name:"随意勾选 1-2-1"},
				{ id:122, pId:12, name:"随意勾选 1-2-2"},
				{ id:2, pId:0, name:"随意勾选 2"},
				{ id:21, pId:2, name:"随意勾选 2-1"},
				{ id:22, pId:2, name:"随意勾选 2-2"},
				{ id:221, pId:22, name:"随意勾选 2-2-1", checked:true},
				{ id:222, pId:22, name:"随意勾选 2-2-2"},
				{ id:23, pId:2, name:"随意勾选 2-3"}
			];
			
			//简单节点树,转为父子children节点树
			simpleRevComplexData = function(nodes){
				var nodePoint = {};
				for(var i in nodes){
					nodePoint[nodes[i].id] = nodes[i];
				}
				var node = [];
				for(var i in nodes){
					if(nodes[i].pId in nodePoint){//if(nodePoint[nodes[i].pId])
						(nodePoint[nodes[i].pId].children || (nodePoint[nodes[i].pId].children = [])).push(nodes[i]);
					}else{//不在则是顶级节点
						node.push(nodes[i]);
					}
				}
				return node;
			};
			
			//递归渲染
			function renderList(data,showArea){
				if(data.length){
					var $ul = $('<ul></ul>');
					for(var i in data){
						var $li = $('<li><span node-id="'+data[i].id+'">'+data[i].name+'</span></li>');
						$ul.append($li);
						if(data[i].children && data[i].children.length>0){
							renderList(data[i].children,$li);
						}
					}
					showArea.append($ul);
				}
			};
			
			//改用on监听动态添加的节点
			$('#aside .aside-content').on('click','span',function(){
				var $this = $(this);
				//ul是否可见
				if($this.next().is(":visible")){
					$this.next().hide();
				}else{
					//判读ul是否存在
					var $ul = $this.next().size()? $this.next().show():$this;
					//隐藏其它兄弟元素
					$ul.closest('li').siblings().find('ul').hide();
				}
			});
			
			
			//方法调用
			var nodes = simpleRevComplexData(nodes);
			
			renderList(nodes,$("#aside").find('.aside-content'));
			
		</script>
	</body>
</html>

  

posted @ 2019-09-12 14:13  littleboyck  阅读(466)  评论(0编辑  收藏  举报