国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

json+jQuery實現的無限級樹形菜單效果代碼

2019-11-20 11:40:48
字體:
來源:轉載
供稿:網友

本文實例講述了json+jQuery實現的無限級樹形菜單效果代碼。分享給大家供大家參考。具體如下:

這里演示json樹形菜單,JS無級樹樹形菜單,引入了jQuery插件,使用遞歸實現獲取無級樹數據并生成DOM結構,可以在JSON數據里 擴展無限級 看結構就明白。

先來看看運行效果截圖:

在線演示地址如下:

http://demo.VeVB.COm/js/2015/jquery-json-tree-style-menu-codes/

具體代碼如下:

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN""http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"><html xmlns="http://www.w3.org/1999/xhtml"><head><meta http-equiv="Content-Type" content="text/html; charset=utf-8" /><script type="text/javascript" src="jquery-1.6.2.min.js"></script><title>JS無級樹樹形菜單</title><style type="text/css">.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;}</style></head><body><div class="btn"><input name="" type="button" id="btn_open" value="全部展開" />  <input name="" type="button" id="btn_close" value="全部收縮" /></div><div id="menuTree" class="menuTree"></div></body></html><script type="text/javascript">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 = "<div><span>"+ o[i]["name"] +"</span><ul>"; }else{ urlstr = "<div><span><a href="+ o[i]["url"] +">"+ o[i]["name"] +"</a></span><ul>";  } str += urlstr; if(o[i]["list"] != null){ forTree(o[i]["list"]); } str += "</ul></div>"; }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); } }); }</script>

希望本文所述對大家的jquery程序設計有所幫助。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 邓州市| 西畴县| 宁陵县| 富宁县| 营口市| 玛纳斯县| 苏州市| 宿迁市| 白山市| 台北市| 项城市| 民勤县| 鲁山县| 岢岚县| 十堰市| 乐业县| 区。| 军事| 大新县| 乡宁县| 成武县| 双牌县| 余干县| 安陆市| 达日县| 凉城县| 楚雄市| 同德县| 武乡县| 三江| 甘洛县| 清河县| 金昌市| 宾阳县| 龙泉市| 茶陵县| 南阳市| 福州市| 陇南市| 武威市| 琼中|