经典实用js+css制作的折叠展开效果导航菜单,在弹出的下级菜单上带有多选框按钮供用户实用,根据自己需求自定义。
<!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=gb2312" /> <meta name="keywords" content="武鸣人网站,武鸣信息网,武鸣本地网,武鸣信息资源平台,减肥,健身,励志,励志语录,js特效,网页特效,www.wuming.ren"> <meta name="description" content="欢迎来到武鸣人信息资源平台,各种信息免费发布,资源共享合作共赢,分享互联网流行的励志语录经典短句,减肥健身健康小常识及打卡记录,收集各种js特效代码。"> <title>实用js+css多级树形折叠展开导航菜单_武鸣人</title> <style type="text/css"> body{margin:0;padding:0;font:12px/1.5 Tahoma,Helvetica,Arial,sans-serif;} ul,li,{margin:0;padding:0;} ul{list-style:none;} #menu_wuming_ren{margin:10px;width:200px;overflow:hidden;} #menu_wuming_ren li{line-height:25px;} #menu_wuming_ren .rem{padding-left:16px;} #menu_wuming_ren .add{background:url(/img/20240423_www_wuming_ren_43.gif) -4px -31px no-repeat;} #menu_wuming_ren .ren{background:url(/img/20240423_www_wuming_ren_43.gif) -4px -7px no-repeat;} #menu_wuming_ren li a{color:#666666;padding-left:5px;outline:none;blr:expression(this.onFocus=this.blur());} #menu_wuming_ren li input{vertical-align:middle;margin-left:5px;} #menu_wuming_ren .two{padding-left:20px;display:none;} </style> </head> <body> <a href="https://www.wuming.ren">武鸣人</a>,各种信息资源免费发布,分享励志语录经典短句,减肥健身常识,各种js特效代码。网站很好记住,wuming.ren(武鸣拼音.ren域名后缀)<hr> <!--欢迎来到武鸣人信息资源平台,各种信息免费发布,资源共享合作共赢,分享互联网流行的励志语录经典短句,减肥健身健康小常识及打卡记录,收集各种js特效代码。--> <script type="text/javascript" src="https://www.wuming.ren/ad/tc.js"></script> <script type="text/javascript" src="https://www.wuming.ren/ad/a.js"></script> <ul id="menu_wuming_ren"> <li> <label><a href="javascript:;">武鸣人一级菜单</a></label> <ul class="two"> <li> <label><a href="javascript:;">武鸣人二级菜单</a></label> <ul class="two"> <li> <label><input type="checkbox" value="123456"><a href="javascript:;">武鸣人三级菜单</a></label> <ul class="two"> <li><label><input type="checkbox" value="123456"><a href="javascript:;">武鸣人四级</a></label></li> <li> <label><input type="checkbox" value="123456"><a href="javascript:;">武鸣人四级</a></label> <ul class="two"> <li> <label><input type="checkbox" value="123456"><a href="javascript:;">武鸣人五级</a></label> <ul class="two"> <li><label><input type="checkbox" value="123456"><a href="javascript:;">六级菜单</a></label></li> <li><label><input type="checkbox" value="123456"><a href="javascript:;">六级菜单</a></label></li> </ul> </li> <li><label><input type="checkbox" value="123456"><a href="javascript:;">武鸣人五级</a></label></li> </ul> </li> </ul> </li> </ul> </li> <li> <label><a href="javascript:;">武鸣人二级菜单</a></label> <ul class="two"> <li><label><input type="checkbox" value="123456"><a href="javascript:;">武鸣人三级菜单</a></label></li> <li><label><input type="checkbox" value="123456"><a href="javascript:;">武鸣人三级菜单</a></label></li> </ul> </li> </ul> </li> </ul> <script type="text/javascript" > function addEvent(el,name,fn){//绑定事件 if(el.addEventListener) return el.addEventListener(name,fn,false); return el.attachEvent('on'+name,fn); }//武鸣人网站https://www.wuming.ren 网站很好记住,wuming.ren(武鸣拼音.ren域名后缀) function nextnode(node){//寻找下一个兄弟并剔除空的文本节点 if(!node)return ; if(node.nodeType == 1) return node; if(node.nextSibling) return nextnode(node.nextSibling); } function prevnode(node){//寻找上一个兄弟并剔除空的文本节点 if(!node)return ; if(node.nodeType == 1) return node; if(node.previousSibling) return prevnode(node.previousSibling); }//武鸣人网站https://www.wuming.ren 网站很好记住,wuming.ren(武鸣拼音.ren域名后缀) function parcheck(self,checked){//递归寻找父亲元素,并找到input元素进行操作 var par = prevnode(self.parentNode.parentNode.parentNode.previousSibling),parspar; if(par&&par.getElementsByTagName('input')[0]){ par.getElementsByTagName('input')[0].checked = checked; parcheck(par.getElementsByTagName('input')[0],sibcheck(par.getElementsByTagName('input')[0])); } }//武鸣人网站https://www.wuming.ren 网站很好记住,wuming.ren(武鸣拼音.ren域名后缀) function sibcheck(self){//判断兄弟节点是否已经全部选中 var sbi = self.parentNode.parentNode.parentNode.childNodes,n=0; for(var i=0;i<sbi.length;i++){ if(sbi[i].nodeType != 1)//由于孩子结点中包括空的文本节点,所以这里累计长度的时候也要算上去 n++; else if(sbi[i].getElementsByTagName('input')[0].checked) n++; } return n==sbi.length?true:false; } addEvent(document.getElementById('menu_wuming_ren'),'click',function(e){//绑定input点击事件,使用menu_wuming_ren根元素代理 e = e||window.event; var target = e.target||e.srcElement; var tp = nextnode(target.parentNode.nextSibling); switch(target.nodeName){ case 'A'://点击A标签展开和收缩树形目录,并改变其样式会选中checkbox if(tp&&tp.nodeName == 'UL'){ if(tp.style.display != 'block' ){ tp.style.display = 'block'; prevnode(target.parentNode.previousSibling).className = 'ren' }else{ tp.style.display = 'none'; prevnode(target.parentNode.previousSibling).className = 'add' } } break; case 'SPAN'://点击图标只展开或者收缩 var ap = nextnode(nextnode(target.nextSibling).nextSibling); if(ap.style.display != 'block' ){ ap.style.display = 'block'; target.className = 'ren' }else{ ap.style.display = 'none'; target.className = 'add' } break; case 'INPUT'://点击checkbox,父亲元素选中,则孩子节点中的checkbox也同时选中,孩子结点取消父元素随之取消 if(target.checked){ if(tp){ var checkbox = tp.getElementsByTagName('input'); for(var i=0;i<checkbox.length;i++) checkbox[i].checked = true; } }else{ if(tp){ var checkbox = tp.getElementsByTagName('input'); for(var i=0;i<checkbox.length;i++) checkbox[i].checked = false; } } parcheck(target,sibcheck(target));//当孩子结点取消选中的时候调用该方法递归其父节点的checkbox逐一取消选中 break; } }); window.onload = function(){//页面加载时给有孩子结点的元素动态添加图标 var labels = document.getElementById('menu_wuming_ren').getElementsByTagName('label'); for(var i=0;i<labels.length;i++){ var span = document.createElement('span'); span.style.cssText ='display:inline-block;height:18px;vertical-align:middle;width:16px;cursor:pointer;'; span.innerHTML = ' ' span.className = 'add'; if(nextnode(labels[i].nextSibling)&&nextnode(labels[i].nextSibling).nodeName == 'UL') labels[i].parentNode.insertBefore(span,labels[i]); else labels[i].className = 'rem' } }//武鸣人网站https://www.wuming.ren 网站很好记住,wuming.ren(武鸣拼音.ren域名后缀) </script> </body> </html>
本文来自武鸣人网站,转载请注明出处