• 实用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特效,js脚本,脚本,广告代码,zzjs,zzjs.net,www.zzjs.net,站长特效 网" />
    <meta name="description" content="www.zzjs.net,站长特效网,站长必备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_zzjs_net{margin:10px;200px;overflow:hidden;}
    #menu_zzjs_net li{line-height:25px;}
    #menu_zzjs_net .rem{padding-left:16px;}
    #menu_zzjs_net .add{background:url(/img/tree_20110125zzjs_net.gif) -4px -31px no-repeat;}
    #menu_zzjs_net .ren{background:url(/img/tree_20110125zzjs_net.gif) -4px -7px no-repeat;}
    #menu_zzjs_net li a{color:#666666;padding-left:5px;outline:none;blr:expression(this.onFocus=this.blur());}
    #menu_zzjs_net li input{vertical-align:middle;margin-left:5px;}
    #menu_zzjs_net .two{padding-left:20px;display:none;}
    </style>
    </head>
    <body>
    <a href="http://www.zzjs.net/">站长特效网</a>,以质量为核心,以实用为目的,打造一流网页特效站!zzjs.net,站长js特效。<hr>
    <!--欢迎来到站长特效网,我们网站收集大量高质量js特效,提供许多广告代码下载,网址:www.zzjs.net,zzjs@msn.com,用.net打造靓站-->
    <ul id="menu_zzjs_net">
    <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);
    }//欢迎来到z站长特效网,我们的网址是www.zzjs.net,很好记,zz站长,js就是js特效,.net打造靓站,还有许多广告代码下载。
    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);
    }//欢迎来到站长z特效网,我们的网址是www.zzjs.net,很好记,zz站长,js就是js特效,.net打造靓站,还有许多广告代码下载。
    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]));
    }
    }//欢迎来到站长特效z网,我们的网址是www.zzjs.net,很好记,zz站长,js就是js特效,.net打造靓站,还有许多广告代码下载。
    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_zzjs_net'),'click',function(e){//绑定input点击事件,使用menu_zzjs_net根元素代理
    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_zzjs_net').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;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'
    }
    }//欢迎来到站长特效网,我们的网址是 z www.zzjs.net,很好记,zz站长,js就是js特效,.net打造靓站,还有许多广告代码下载。
    </script>
    </body>
    </html>

  • 相关阅读:
    MySQL实现了四种通信协议
    深入了解Windows句柄到底是什么
    Linux虚拟地址空间布局以及进程栈和线程栈总结
    malloc 函数详解
    数组指针和指针数组的区别
    Linux中sudo配置
    ctrl+c,ctrl+d,ctrl+z在linux程序中意义和区别
    linux select函数详解
    linux grep命令详解
    Linux find 用法示例
  • 原文地址:https://www.cnblogs.com/skyay/p/3826027.html
Copyright © 2020-2023  润新知