国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁技術(shù)文章
文章詳情頁

javascript - 一個(gè)js選項(xiàng)卡的例子中某次遍歷的意思不太懂。。。

瀏覽:100日期:2023-04-18 15:14:51

問題描述

<!DOCTYPE html><html lang='en'><head> <meta charset='UTF-8'> <title>Document</title> <style>*{ margin:0; padding: 0;}.active{ background: red;}#main p{ width: 200px; height: 200px; background: yellow; display: none;} </style> <script>window.onload=function(){ var op = document.getElementById(’main’); var oIp = op.getElementsByTagName(’input’); var ap = op.getElementsByTagName(’p’); for(var i=0;i<oIp.length;i++) {oIp[i].index=i;oIp[i].onclick=function(){ for(var i=0;i<oIp.length;i++) // 就是這兒 {oIp[i].className='';ap[i].style.display=''; } this.className='active'; ap[this.index].style.display='block'} }} </script></head><body> <p id='main'><input type='button' value='111'><input type='button' value='222'><input type='button' value='333'><input type='button' value='444'><p style='display: block'>1</p><p>2</p><p>3</p><p>4</p> </p></body></html>

這是一個(gè)網(wǎng)上的選項(xiàng)卡的例子,然后不太懂例子中js部分,第二次for循環(huán)的意思是什么。。。QAQ

問題解答

回答1:

外面一層的for,主要是為了給每一個(gè)選項(xiàng)卡按鈕綁定onclick事件。

而里面的這個(gè)for,是在綁定的onclick事件之內(nèi),它的作用是,當(dāng)點(diǎn)擊了被綁定的選項(xiàng)卡時(shí),遍歷所有的選項(xiàng)卡,把不是當(dāng)前點(diǎn)擊的選項(xiàng)卡都重置成隱藏狀態(tài),然后這個(gè)for下面的:

this.className='active';ap[this.index].style.display='block';

是把當(dāng)前點(diǎn)擊項(xiàng)對應(yīng)的標(biāo)簽頁顯示出來。

這樣,就只有當(dāng)前點(diǎn)擊項(xiàng)對應(yīng)的標(biāo)簽會(huì)顯示出來,其余的標(biāo)簽頁都被隱藏。如果沒有這個(gè)for,當(dāng)你點(diǎn)擊第一個(gè)標(biāo)簽,第一個(gè)標(biāo)簽顯示出來。然后你點(diǎn)擊了第二個(gè)標(biāo)簽,第二個(gè)標(biāo)簽顯示出來,現(xiàn)在就有第一個(gè)和第二個(gè)標(biāo)簽頁同時(shí)顯示;接著你點(diǎn)擊了第三個(gè)標(biāo)簽,前面兩個(gè)沒有隱藏,而第三個(gè)標(biāo)簽頁顯示出來,…………這樣,到最后,你點(diǎn)完所有的標(biāo)簽按鈕時(shí),所有的標(biāo)簽頁都顯示出來,這顯然不是標(biāo)簽頁的效果。

為了使當(dāng)前點(diǎn)擊之外的標(biāo)簽頁都隱藏掉,所以在顯示當(dāng)前標(biāo)簽頁之前,先用for遍歷,把所有標(biāo)簽頁隱藏。

回答2:

大致的功能是要實(shí)現(xiàn)點(diǎn)擊切換到該選項(xiàng)卡。所謂切換,就是其他隱藏,當(dāng)前顯示。而你說的那部分就是隱藏所有 input 的。就是每次點(diǎn)擊是,都遍歷一次 所有 input, 去掉 class 和 display 屬性,藏起來,然后單單為 this, 也就是當(dāng)前點(diǎn)擊項(xiàng)加上 class 和 display 屬性,顯示出來

回答3:

我給代碼打上注釋,看到注釋就知道了!代碼原理就是先清除所有input的類名和隱藏所有的p,然后給當(dāng)前點(diǎn)擊的input加上類名,顯示當(dāng)前索引對應(yīng)的p!

<script> window.onload=function() {var op = document.getElementById(’main’);var oIp = op.getElementsByTagName(’input’);var ap = op.getElementsByTagName(’p’);//遍歷inputfor(var i=0;i<oIp.length;i++){ //自定義屬性index,() oIp[i].index=i; //給每一個(gè)input綁定點(diǎn)擊事件 oIp[i].onclick=function() { //首先,清除掉所有的input的類名和p的樣式(就是讓所有p先隱藏)。for(var i=0;i<oIp.length;i++) // 就是這兒{ oIp[i].className=''; ap[i].style.display='';}//當(dāng)前的input添加類名this.className='active';//根據(jù)當(dāng)前input的索引,把對應(yīng)的索引的p加上樣式(就是讓對應(yīng)的索引的p現(xiàn)實(shí))ap[this.index].style.display='block' }} } </script>

標(biāo)簽: JavaScript
相關(guān)文章:
主站蜘蛛池模板: 日韩欧美在线观看一区 | 成人性视频在线三级 | 亚洲图片国产日韩欧美 | 日韩免费观看一级毛片看看 | 精品一区二区三区四区在线 | videos欧美丰满肥婆 | 欧美精品一区二区三区视频 | 一 级做人爱全视频在线看 一本不卡 | 色播亚洲视频在线观看 | 欧美亚洲视频在线观看 | 欧美日韩一区二区不卡三区 | 网站免费满18成年在线观看 | 国产性自爱拍偷在在线播放 | 日韩精品一区二区三区乱码 | 快色网站| a级国产乱理伦片在线观看国 | 日本欧美亚洲 | 国产日本韩国不卡在线视频 | 福利片免费一区二区三区 | 一区二区三区欧美视频 | 亚洲国产成人精品久久 | 国产欧美日韩在线不卡第一页 | 欧美一区二区三区在线 | 日本欧美在线视频 | 中文字幕成人免费视频 | 亚洲人成高清 | 国产成人香蕉久久久久 | 韩日一级 | 久草免费新视频 | 欧洲一级毛片免费 | 国产区在线免费观看 | 久久精品国产精品亚洲艾 | 精品玖玖玖视频在线观看 | 免费精品一区二区三区在线观看 | 日韩一区二区三区在线视频 | 99视频在线观看免费 | 中文字幕综合 | 国产自线一二三四2021 | 狠狠色狠狠色狠狠五月ady | 国产欧美日韩精品第三区 | 久久久久久91精品色婷婷 |