亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

JS仿QQ好友列表展開、收縮功能(第二篇)

 更新時間:2017年07月07日 17:05:08   作者:erdouzhang  
這篇文章主要介紹了JS仿QQ好友列表展開、收縮功能,當(dāng)點擊一個li元素,其他li元素上的類名清除掉。代碼簡單易懂,需要的朋友可以參考下

上篇的基礎(chǔ)上繼續(xù)完善,點擊一個li元素,其他li元素上的類名清除掉。

效果圖如下所示:

這里寫圖片描述

js:

<script>
 window.onload = function(){ 
 var list = document.getElementById('list'); 
 var ah2 = list.getElementsByTagName('h2'); 
 var uls = list.getElementsByTagName('ul');
 var lis = null;//用于下面的存儲
 var arrli = [];//
 // h2要和下面的ul進(jìn)行匹配,所以我們要用索引值,給h2身上添加索引值
 for(var i=0;i<ah2.length;i++){ 
 ah2[i].index = i;//給h2添加索引值,點擊誰就給誰添加索引值
 ah2[i].onclick = function(){
 if(this.className == ''){//判斷所點擊的h2標(biāo)簽是否有類,
  //this.index指h2身上的索引數(shù),this指h2,h2的索引值為this.index
  uls[this.index].style.display = 'block'; 
  this.className = 'active';//給當(dāng)前點擊的h2添加類,更改箭頭方向
 }else{
  uls[this.index].style.display = 'none';
  this.className = '';
 }
 }
 }
 // 找到list里的所有ul,共有三個ul,所以用到for循環(huán)
 for(var i=0;i<uls.length;i++){//找到每一組ul
 lis = uls[i].getElementsByTagName('li');//找到uls中的所有l(wèi)i元素,存入到lis中,為什么要存一下呢?因為找到的li元素是一組元素的集合,要給每一個元素添加點擊事件,存起來之后要再來一次for循環(huán),for套for中間沒有函數(shù)包著所以得換一個變量
 for(var j=0;j<lis.length;j++){//找到每組ul中的所有l(wèi)i
 arrli.push(lis[j]); //把每個li放到數(shù)組中,因為是要操作一組li中的每個,所以我們把它拎出來放在一起方便操作
 }
 }
 // 找到每個li之后進(jìn)行點擊事件操作
 for(var i=0;i<arrli.length;i++){
 arrli[i].onclick = function(){
 // 清除所有類名,只給當(dāng)前點擊的添加
 // 只保留一個li元素添加類名
 // 為什么用的是i呢?因為for套for它們中間有一層函數(shù)隔開(有函數(shù)包含的情況下作用域發(fā)生了改變),所以可以使用同樣的i名稱
 for(var i=0;i<arrli.length;i++){
  arrli[i].className = '';//去掉點擊所有添加的類
 }
 this.className = 'hover';//給當(dāng)前點擊的li元素添加類名
 }
 }
 }
</script>

注意:

怎么區(qū)分for循環(huán)中有的用 i 有的用 j?

答:①如果是一個for循環(huán),那么用 i 或者 j 哪個都行,一般是用 i .
②如果是兩個for嵌套,那么看兩個for中間有沒有函數(shù)隔開:1.有函數(shù)隔開,那么這兩個for循環(huán)中的變量都可以用 i 。2.沒有函數(shù)隔開,那么這兩個for循環(huán)中的變量不能使用相同的 i 來命名,一個 i ,一個 j .

例一:

下面是兩個嵌套的for循環(huán)中沒有函數(shù)隔開,所以一個是 i ,一個是 j .

for(var i=0;i<uls.length;i++){//找到每一組ul
 lis = uls[i].getElementsByTagName('li');
 for(var j=0;j<lis.length;j++){//找到每組ul中的所有l(wèi)i
 arrli.push(lis[j]); 
 }
}

例二:

也是兩個嵌套的for循環(huán)中,有一個函數(shù)隔開,那么就可以使用同一個 i 來命名。

for(var i=0;i<arrli.length;i++){
 arrli[i].onclick = function(){ 
 for(var i=0;i<arrli.length;i++){
 arrli[i].className = '';//去掉點擊所有添加的類
 }
 this.className = 'hover';//給當(dāng)前點擊的li元素添加類名
 }
}

以上所述是小編給大家介紹的JS仿QQ好友列表展開、收縮功能,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!

相關(guān)文章

最新評論