json結構:

var Menu = [{ tit:"一級菜單", submenu:[{ tit:"二級菜單", url:"", func:function(){ alert('what do you want to do?'); } },{ tit:"二級菜單", func:function(){ alert('do what?'); }, submenu:[{ tit:"三級菜單", url:"", submenu:[{ tit:"四級菜單", url:"" },{ tit:"四級菜單", url:"" }] },{ tit:"三級菜單", url:"" }] }] },{ tit:"一級菜單", submenu:[{ tit:"二級菜單", url:"" },{ tit:"二級菜單", submenu:[{ tit:"三級菜單", url:"" },{ tit:"三級菜單", url:"" }] }] }];
構建菜單處理函數

/* * @構建樹形菜單 * @arrJson:json數據 * @container:菜單容器 */ function menuTree(jsonArr,container,treeId){ var oText,oUrl; var oUl = document.createElement('ul'); for(var i = 0 ;i < jsonArr.length; i++){ var oLi = document.createElement('li'); oUrl = jsonArr[i].url || "javascript:void(0)"; oText = jsonArr[i].tit; if(jsonArr[i].submenu){ oLi.innerHTML ='<a href="'+oUrl+'">'+oText+'</a>'; menuTree(jsonArr[i].submenu,oLi);//遞歸構建子菜單 }else{ oLi.innerHTML = '<a href="'+oUrl+'">'+oText+'</a>'; } //自定義函數 if(typeof jsonArr[i].func =="function"){ oLi.getElementsByTagName('a')[0].func = jsonArr[i].func; oLi.getElementsByTagName('a')[0].onclick=function(){ this.func(); } } oUl.appendChild(oLi); } //最外層容器事件委托 if(treeId){ document.getElementById(treeId).onclick = function(e){ var event = e || window.event; var target = event.target||event.srcElement; var next = target.nextSibling; if(target.nodeName.toLowerCase() == "a"){ if(next){ if(next.style.display=="" || next.style.display=="block"){ next.style.display="none"; }else{ next.style.display="block"; } } } } } container.appendChild(oUl); }
完整demo:

<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>json樹形菜單</title> </head> <body> <h2>構建json樹形菜單</h2> <div class="tree" id="tree"></div> <script type="text/javascript"> window.onload = function(){ var Menu = [{ tit:"一級菜單", submenu:[{ tit:"二級菜單", url:"", func:function(){ alert('what do you want to do?'); } },{ tit:"二級菜單", func:function(){ alert('do what?'); }, submenu:[{ tit:"三級菜單", url:"", submenu:[{ tit:"四級菜單", url:"" },{ tit:"四級菜單", url:"" }] },{ tit:"三級菜單", url:"" }] }] },{ tit:"一級菜單", submenu:[{ tit:"二級菜單", url:"" },{ tit:"二級菜單", submenu:[{ tit:"三級菜單", url:"" },{ tit:"三級菜單", url:"" }] }] }]; //構建菜單 menuTree(Menu,document.getElementById('tree'),'tree'); } /* * @構建樹形菜單 * @arrJson:json數據 * @container:菜單容器 */ function menuTree(jsonArr,container,treeId){ var oText,oUrl; var oUl = document.createElement('ul'); for(var i = 0 ;i < jsonArr.length; i++){ var oLi = document.createElement('li'); oUrl = jsonArr[i].url || "javascript:void(0)"; oText = jsonArr[i].tit; if(jsonArr[i].submenu){ oLi.innerHTML ='<a href="'+oUrl+'">'+oText+'</a>'; menuTree(jsonArr[i].submenu,oLi);//遞歸構建子菜單 }else{ oLi.innerHTML = '<a href="'+oUrl+'">'+oText+'</a>'; } //自定義函數 if(typeof jsonArr[i].func =="function"){ oLi.getElementsByTagName('a')[0].func = jsonArr[i].func; oLi.getElementsByTagName('a')[0].onclick=function(){ this.func(); } } oUl.appendChild(oLi); } //最外層容器事件委托 if(treeId){ document.getElementById(treeId).onclick = function(e){ var event = e || window.event; var target = event.target||event.srcElement; var next = target.nextSibling; if(target.nodeName.toLowerCase() == "a"){ if(next){ if(next.style.display=="" || next.style.display=="block"){ next.style.display="none"; }else{ next.style.display="block"; } } } } } container.appendChild(oUl); } </script> </body> </html>
效果圖:
完整實例: