<!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>
<title>实用的多级树形展开菜单</title>
<meta http-equiv="content-type" content="text/html;charset=gb2312">
<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;}
#root{margin:10px;width:200px;overflow:hidden;}
#root li{line-height:25px;}
#root .rem{padding-left:16px;}
#root .add{background:url(20101031213041133.gif) -4px -31px no-repeat;}
#root .ren{background:url(20101031213041133.gif) -4px -7px no-repeat;}
#root li a{color:#666666;padding-left:5px;outline:none;blr:expression(this.onFocus=this.blur());}
#root li input{vertical-align:middle;margin-left:5px;}
#root .two{padding-left:20px;display:none;}
</style>
</head>
<body>
<ul id="root"> <li><label><input id="comp0" type="checkbox" value="comp0" /><a href="#">xxx公司</a></label><ul class="two"><li><label><input id="depat0" type="checkbox" value="depat0" /><a href="#">公司领导</a></label><ul class="two"></ul></li><li><label><input id="depat1" type="checkbox" value="depat1" /><a href="#">总经理工作部</a></label><ul class="two"></ul></li><li><label><input id="depat2" type="checkbox" value="depat2" /><a href="#">财务部</a></label><ul class="two"></ul></li><li><label><input id="depat3" type="checkbox" value="depat3" /><a href="#">计划合同部</a></label><ul class="two"></ul></li><li><label><input id="depat4" type="checkbox" value="depat4" /><a href="#">生产技术部</a></label><ul class="two"><li><input id="4a3ee91c4459dcac" type="checkbox" value="黄xx" /><a href="#">黄xx</a></li><li><input id="8a76eb05032b2897" type="checkbox" value="周有良" /><a href="#">周xx</a></li><li><input id="7467b3d2c422c144" type="checkbox" value="何xxx" /><a href="#">何xx</a></li><li><input id="1ee9be8bcbee2501" type="checkbox" value="卢xx" /><a href="#">卢xx</a></li><li><input id="b9dae1e7835aa8bf" type="checkbox" value="xx平" /><a href="#">粟xx</a></li><li><input id="eb3b8838cc263b8d" type="checkbox" value="邱xxx" /><a href="#">邱xx</a></li><li><input id="f26d9253b9c0774b" type="checkbox" value="xx全" /><a href="#">xx全</a></li></ul></li><li><label><input id="depat5" type="checkbox" value="depat5" /><a href="#">工程部</a></label><ul class="two"></ul></li><li><label><input id="depat6" type="checkbox" value="depat6" /><a href="#">检修部</a></label><ul class="two"><li><label><input id="depat0" type="checkbox" value="depat0" /><a href="#">机械班</a></label><ul class="two"><li><input id="a53f74d408e57484" type="checkbox" value="xxx强" /><a href="#">xx强</a></li><li><input id="bc6987445b3687ed" type="checkbox" value="邓权" /><a href="#">xx权</a></li><li><input id="b6e3f9b11cbbd2bc" type="checkbox" value="xxxx滨" /><a href="#">覃xx</a></li><li><input id="ee50cbbd04fe4058" type="checkbox" value="xx鼓" /><a href="#">xx鼓</a></li><li><input id="8473d5a3a7d4e505" type="checkbox" value="李成龙" /><a href="#">李xx龙</a></li></ul></li><li><label><input id="depat1" type="checkbox" value="depat1" /><a href="#">电气班</a></label><ul class="two"><li><input id="b04896a0f9efdb09" type="checkbox" value="黄佩东" /><a href="#">xx东</a></li><li><input id="897c20d019265cb4" type="checkbox" value="xxx冬" /><a href="#">xx冬</a></li><li><input id="36d661ca4f396072" type="checkbox" value="xx" /><a href="#">xxx</a></li><li><input id="e52d4531b4b92430" type="checkbox" value="李椒" /><a href="#">李椒</a></li></ul></li><li><label><input id="depat2" type="checkbox" value="depat2" /><a href="#">水工班</a></label><ul class="two"></ul></li><li><label><input id="depat3" type="checkbox" value="depat3" /><a href="#">自动化班</a></label><ul class="two"><li><input id="ef39343943143ec7" type="checkbox" value="xxx雷" /><a href="#">贾xx</a></li></ul></li><li><label><input id="depat4" type="checkbox" value="depat4" /><a href="#">检修本部</a></label><ul class="two"><li><input id="dd6ace541a64ff31" type="checkbox" value="xxx新" /><a href="#">xxx新</a></li><li><input id="4de3b6f125d1bdf" type="checkbox" value="韦xx" /><a href="#">xx鹏</a></li><li><input id="945dfb22811b6e28" type="checkbox" value="xxx涨" /><a href="#">xxx涨</a></li><li><input id="78e91119f39af8f7" type="checkbox" value="廖xx丽" /><a href="#">xx丽</a></li></ul></li></ul></li><li><label><input id="depat7" type="checkbox" value="depat7" /><a href="#">xxxx部</a></label><ul class="two"></ul></li></ul></li></li><li><label><input id="comp1" type="checkbox" value="comp1" /><a href="#">xx物业公司</a></label><ul class="two"></ul></li></li><ul>
</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);
}
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);
}
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]));
}
}
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('root'),'click',function(e){//绑定input点击事件,使用root根元素代理
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('root').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'
}
}
</script>
</body>
</html>