欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

js一般方法改寫成面向?qū)ο蠓椒ǖ臒o限級折疊菜單示例代碼

 更新時間:2013年07月04日 17:04:26   作者:  
本例是應(yīng)用別人的例子,原來那位老兄是用一般方法寫成的無限級折疊菜單,通過了一些簡化修改,將原來的例子改成了面向?qū)ο蟮姆绞?/div>
本例是應(yīng)用別人的例子,原來那位老兄是用一般方法寫成的無限級折疊菜單,在此先感謝他!后來我就通過了一些簡化修改,將原來的例子改成了面向?qū)ο蟮姆绞?,實例中的展開與閉合的小圖標可以自己重新添加,從而更好的查看效果。
復(fù)制代碼 代碼如下:

<!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>很實用的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;}
a{text-decoration: none;}
#root{margin:10px;width:200px;overflow:hidden;}
#root li{line-height:25px;}
#root .rem{padding-left:16px;}
#root .add{background:url(treeico.gif) -4px -31px no-repeat;}
#root .ren{background:url(treeico.gif) -4px -7px no-repeat;}
#root li a{color:#666666;padding-left:5px;outline:none;blr:expression(this.onFocus=this.blur());}
#root .two{padding-left:20px;display:none;}
</style>
</head>
<body>
<ul id="root">
<li>
<label><a href="javascript:;">校訊通</a></label>
<ul class="two">
<li>
<label><a href="javascript:;">沈陽市</a></label>
<ul class="two">
<li>
<label><a href="javascript:;">二小</a></label>
<ul class="two">
<li><label><a href="javascript:;">二年級</a></label></li>
<li>
<label><a href="javascript:;">三年級</a></label>
<ul class="two">
<li>
<label><a href="javascript:;">一班</a></label>
<ul class="two">
<li><label><a href="javascript:;">張三</a></label></li>
<li>
<label><a href="javascript:;">王五</a></label>
<ul class="two">
<li><label><a href="javascript:;">班長</a></label></li>
<li><label><a href="javascript:;">學(xué)習(xí)委員</a></label></li>
</ul>
</li>
</ul>
</li>
<li><label><a href="javascript:;">實驗班</a></label></li>
</ul>
</li>
</ul>
</li>
</ul>
</li>
<li>
<label><a href="javascript:;">撫順市</a></label>
<ul class="two">
<li><label><a href="javascript:;">二小</a></label></li>
<li><label><a href="javascript:;">一中</a></label></li>
</ul>
</li>
</ul>
</li>
</ul>
<script type="text/javascript" >
/**一般JS方法
function addEvent(el,name,fn){//綁定事件
if(el.addEventListener) return el.addEventListener(name,fn,false);
return el.attachEvent('on'+name,fn);
}
function nextnode(node){//尋找下一個兄弟并剔除空的文本節(jié)點
if(!node)return ;
if(node.nodeType == 1)
return node;
if(node.nextSibling)
return nextnode(node.nextSibling);
}
function prevnode(node){//尋找上一個兄弟并剔除空的文本節(jié)點
if(!node)return ;
if(node.nodeType == 1)
return node;
if(node.previousSibling)
return prevnode(node.previousSibling);
}
addEvent(document.getElementById('root'),'click',function(e){//綁定點擊事件,使用root根元素代理
e = e||window.event;
var target = e.target||e.srcElement;
var tp = nextnode(target.parentNode.nextSibling);
switch(target.nodeName){
case 'A'://點擊A標簽展開和收縮樹形目錄,并改變其樣式
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;
}
});
window.onload = function(){//頁面加載時給有孩子結(jié)點的元素動態(tài)添加圖標
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'
}
}
**/
//面向?qū)ο蠓椒?
var Tree = function(o){
this.root = document.getElementById(o);
this.labels = this.root.getElementsByTagName('label');
var that = this;
this.int();
Tree.prototype.addEvent(this.root,'click',function(e){that.treeshow(e)});
}
Tree.prototype = {
int:function(){//初始化頁面,加載時給有孩子結(jié)點的元素動態(tài)添加圖標
for(var i=0;i<this.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(this.nextnode(this.labels[i].nextSibling)&&this.nextnode(this.labels[i].nextSibling).nodeName == 'UL')
this.labels[i].parentNode.insertBefore(span,this.labels[i]);
else
this.labels[i].className = 'rem'
}
},
treeshow:function(e){
e = e||window.event;
var target = e.target||e.srcElement;
var tp = this.nextnode(target.parentNode.nextSibling);
switch(target.nodeName){
case 'A'://點擊A標簽展開和收縮樹形目錄,并改變其樣式
if(tp&&tp.nodeName == 'UL'){
if(tp.style.display != 'block' ){
tp.style.display = 'block';
this.prevnode(target.parentNode.previousSibling).className = 'ren'
}else{
tp.style.display = 'none';
this.prevnode(target.parentNode.previousSibling).className = 'add'
}
}
break;
case 'SPAN'://點擊圖標只展開或者收縮
var ap = this.nextnode(this.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;
}
},
addEvent:function(el,name,fn){//綁定事件
if(el.addEventListener) return el.addEventListener(name,fn,false);
return el.attachEvent('on'+name,fn);
},
nextnode:function(node){//尋找下一個兄弟并剔除空的文本節(jié)點
if(!node)return ;
if(node.nodeType == 1)
return node;
if(node.nextSibling)
return this.nextnode(node.nextSibling);
},
prevnode:function(node){//尋找上一個兄弟并剔除空的文本節(jié)點
if(!node)return ;
if(node.nodeType == 1)
return node;
if(node.previousSibling)
return prevnode(node.previousSibling);
}
}
tree = new Tree("root");//實例化應(yīng)用
</script>
</body>
</html>

相關(guān)文章

  • JavaScript常見繼承模式實例小結(jié)

    JavaScript常見繼承模式實例小結(jié)

    這篇文章主要介紹了JavaScript常見繼承模式,結(jié)合實例形式總結(jié)分析了javascript原型鏈繼承、構(gòu)造函數(shù)繼承、組合繼承、原型式繼承、寄生式繼承等相關(guān)實現(xiàn)技巧與操作注意事項,需要的朋友可以參考下
    2019-01-01
  • 微信小程序自定義組件的實現(xiàn)方法及自定義組件與頁面間的數(shù)據(jù)傳遞問題

    微信小程序自定義組件的實現(xiàn)方法及自定義組件與頁面間的數(shù)據(jù)傳遞問題

    這篇文章主要介紹了微信小程序自定義組件的實現(xiàn)方法及自定義組件與頁面間的數(shù)據(jù)傳遞 ,需要的朋友可以參考下
    2018-10-10
  • JavaScript字符串轉(zhuǎn)數(shù)字的簡單實現(xiàn)方法

    JavaScript字符串轉(zhuǎn)數(shù)字的簡單實現(xiàn)方法

    這篇文章主要給大家介紹了關(guān)于JavaScript字符串轉(zhuǎn)數(shù)字的簡單實現(xiàn)方法,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-11-11
  • js實現(xiàn)購物網(wǎng)站放大鏡功能

    js實現(xiàn)購物網(wǎng)站放大鏡功能

    這篇文章主要為大家詳細介紹了js實現(xiàn)購物網(wǎng)站放大鏡功能,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-06-06
  • Javascript中call,apply,bind方法的詳解與總結(jié)

    Javascript中call,apply,bind方法的詳解與總結(jié)

    本文主要Javascript中call,apply,bind方法的進行全面分析,并在文章結(jié)尾對call,apply,bind方法的聯(lián)系和區(qū)別做了總結(jié),具有很好的參考價值,需要的朋友一起來看下吧
    2016-12-12
  • JS隨機漂浮廣告代碼具體實例

    JS隨機漂浮廣告代碼具體實例

    這篇文章主要介紹了JS隨機漂浮廣告代碼具體實例,有需要的朋友可以參考一下
    2013-11-11
  • 最全面的JS倒計時代碼

    最全面的JS倒計時代碼

    這篇文章主要為大家詳細介紹了最全面的JS倒計時代碼,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2016-09-09
  • JavaScript提升機制Hoisting詳解

    JavaScript提升機制Hoisting詳解

    這篇文章主要介紹了JavaScript提升機制Hoisting詳解,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2019-10-10
  • layui 阻止圖片上傳的實例(before方法)

    layui 阻止圖片上傳的實例(before方法)

    今天小編就為大家分享一篇layui 阻止圖片上傳的實例(before方法),具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-09-09
  • DIV始終居中的js代碼

    DIV始終居中的js代碼

    這篇文章主要介紹了DIV始終居中的js代碼,需要的朋友可以參考下
    2014-02-02

最新評論