問(wèn)題:為什么onclick事件能正確獲取到我點(diǎn)的是數(shù)組哪個(gè)元素,還有下標(biāo)。(tab,tabPos)
for循環(huán)至setTabHandler(tab, i),執(zhí)行函數(shù) 循環(huán)調(diào)用3次該函數(shù),它不是直接循環(huán)完了嗎?
這段javascript代碼應(yīng)該不是從我點(diǎn)擊開(kāi)始o(jì)nclick事件才執(zhí)行的吧?
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>Tabbed info box</title>
<style>
html {
font-family: sans-serif;
}
* {
box-sizing: border-box;
}
body {
margin: 0;
}
.info-box {
border: 1px solid red;
width: 452px;
height: 400px;
margin: 0 auto;
}
.info-box ul {
padding-left: 0;
margin-top: 0;
}
.info-box li {
float: left;
list-style-type: none;
width: 150px;
}
.info-box li a {
border: 1px solid black;
display: block;
text-decoration: none;
width: 100%;
line-height: 3;
background-color: red;
color: black;
text-align: center;
}
.info-box li a:focus, .info-box li a:hover {
background-color: #a60000;
color: white;
}
.info-box li a.active {
background-color: #a60000;
color: white;
}
.info-box li a.demo {
background-color: #030303;
color: white;
}
.info-box .panels {
position:relative;
height: 352px;
clear: both;
}
.info-box article {
position: absolute;
top: 0;
left: 0;
height: 352px;
padding: 10px;
color: white;
background-color: #a60000;
}
.info-box .active-panel {
z-index: 1;
}
</style>
</head>
<body>
<section class="info-box">
<ul>
<li><a class="active" href="#" >Tab 1</a></li>
<li><a href="#">Tab 2</a></li>
<li><a href="#">Tab 3</a></li>
</ul>
<div class="panels">
<article class="active-panel">
<h2>The first tab</h2>
<p >1Lorem ipsum dolor sit amet,</p>
</article>
<article>
<h2>The second tab</h2>
<p>This tab hasn't got any Lorem Ipsum in it. But the content isn't very exciting all the same.</p>
</article>
<article>
<h2>The third tab</h2>
<p>3Lorem ipsum dolor sit </p>
<ol>
<li>dui neque eleifend lorem, a auctor libero turpis at sem.</li>
<li>Aliquam ut porttitor urna.</li>
<li>Nulla facilisi</li>
</ol>
</article>
</div>
</section>
<script>
var tabs = document.querySelectorAll('.info-box li a');
var panels = document.querySelectorAll('.info-box article');
for(i = 0; i < tabs.length; i++) {
var tab = tabs[i];
setTabHandler(tab, i);
}
function setTabHandler(tab, tabPos) {
tab.onclick = function() {
alert(tabPos);
for(i = 0; i < tabs.length; i++) {
if(tabs[i].getAttribute('class')) {
tabs[i].removeAttribute('class');
}
}
tab.setAttribute('class', 'demo');
for(i = 0; i < panels.length; i++) {
if(panels[i].getAttribute('class')) {
panels[i].removeAttribute('class');
}
}
panels[tabPos].setAttribute('class', 'active-panel');
}
}
</script>
</body>
</html>為什么onclick事件能正確獲取到我點(diǎn)的是數(shù)組哪個(gè)元素,還有下標(biāo)。(tab,tabPos)
因?yàn)橐婚_(kāi)始就已經(jīng)通過(guò)循環(huán)把 元素 和 下標(biāo) 傳遞給 setHandler 了。
for循環(huán)至setTabHandler(tab, i),執(zhí)行函數(shù) 循環(huán)調(diào)用3次該函數(shù),它不是直接循環(huán)完了嗎?
每循環(huán)一次就給對(duì)應(yīng)下標(biāo)的元素注冊(cè)監(jiān)聽(tīng)函數(shù),然后就結(jié)束了這沒(méi)錯(cuò)。
這段javascript代碼應(yīng)該不是從我點(diǎn)擊開(kāi)始o(jì)nclick事件才執(zhí)行的吧?
只有 tab.onclick = function () { ... } 這一段是你點(diǎn)擊后才執(zhí)行的,其他的都是頁(yè)面一加載完就執(zhí)行了。
為什么onclick事件能正確獲取到我點(diǎn)的是數(shù)組哪個(gè)元素,還有下標(biāo)。(tab,tabPos)
這牽涉到執(zhí)行順序,因變數(shù)在一開(kāi)始就給值,所以下方已經(jīng)注冊(cè) tabs, panels
for循環(huán)至setTabHandler(tab, i),執(zhí)行函數(shù) 循環(huán)調(diào)用3次該函數(shù),它不是直接循環(huán)完了嗎?
確實(shí)循環(huán)完了,但因 setTabHandler 中注冊(cè)了 onclick 事件,所以后續(xù) tab 被點(diǎn)擊時(shí)會(huì)觸發(fā)已被注冊(cè)的 onclick 事件
這段javascript代碼應(yīng)該不是從我點(diǎn)擊開(kāi)始o(jì)nclick事件才執(zhí)行的吧?
setTabHandler 在程式第一次執(zhí)行時(shí)就被呼叫,后續(xù)點(diǎn)擊時(shí)觸發(fā)的是
function() {
alert(tabPos);
for(i = 0; i < tabs.length; i++) {
if(tabs[i].getAttribute('class')) {
tabs[i].removeAttribute('class');
}
}
tab.setAttribute('class', 'demo');
for(i = 0; i < panels.length; i++) {
if(panels[i].getAttribute('class')) {
panels[i].removeAttribute('class');
}
}
panels[tabPos].setAttribute('class', 'active-panel');
}
這段程式碼
在瀏覽器中,tags,panels已經(jīng)是全局變量,tab.onclick=是對(duì)dom元素click事件屬性賦值,這是前提。
每個(gè)tab都有一個(gè)click事件,而事件在初始化的時(shí)候已經(jīng)通過(guò)tabPos獲取到了下標(biāo),可以理解為:
tab[0] click對(duì)應(yīng)的下標(biāo)是 0
tab[1] click對(duì)應(yīng)的下標(biāo)是 1
...
代碼實(shí)際上在頁(yè)面加載到該塊代碼時(shí)已經(jīng)執(zhí)行了,因此頁(yè)面渲染完成后對(duì)應(yīng)元素tab已經(jīng)有click事件屬性(你可以用開(kāi)發(fā)者工具查看)。
北大青鳥(niǎo)APTECH成立于1999年。依托北京大學(xué)優(yōu)質(zhì)雄厚的教育資源和背景,秉承“教育改變生活”的發(fā)展理念,致力于培養(yǎng)中國(guó)IT技能型緊缺人才,是大數(shù)據(jù)專業(yè)的國(guó)家
達(dá)內(nèi)教育集團(tuán)成立于2002年,是一家由留學(xué)海歸創(chuàng)辦的高端職業(yè)教育培訓(xùn)機(jī)構(gòu),是中國(guó)一站式人才培養(yǎng)平臺(tái)、一站式人才輸送平臺(tái)。2014年4月3日在美國(guó)成功上市,融資1
北大課工場(chǎng)是北京大學(xué)校辦產(chǎn)業(yè)為響應(yīng)國(guó)家深化產(chǎn)教融合/校企合作的政策,積極推進(jìn)“中國(guó)制造2025”,實(shí)現(xiàn)中華民族偉大復(fù)興的升級(jí)產(chǎn)業(yè)鏈。利用北京大學(xué)優(yōu)質(zhì)教育資源及背
博為峰,中國(guó)職業(yè)人才培訓(xùn)領(lǐng)域的先行者
曾工作于聯(lián)想擔(dān)任系統(tǒng)開(kāi)發(fā)工程師,曾在博彥科技股份有限公司擔(dān)任項(xiàng)目經(jīng)理從事移動(dòng)互聯(lián)網(wǎng)管理及研發(fā)工作,曾創(chuàng)辦藍(lán)懿科技有限責(zé)任公司從事總經(jīng)理職務(wù)負(fù)責(zé)iOS教學(xué)及管理工作。
浪潮集團(tuán)項(xiàng)目經(jīng)理。精通Java與.NET 技術(shù), 熟練的跨平臺(tái)面向?qū)ο箝_(kāi)發(fā)經(jīng)驗(yàn),技術(shù)功底深厚。 授課風(fēng)格 授課風(fēng)格清新自然、條理清晰、主次分明、重點(diǎn)難點(diǎn)突出、引人入勝。
精通HTML5和CSS3;Javascript及主流js庫(kù),具有快速界面開(kāi)發(fā)的能力,對(duì)瀏覽器兼容性、前端性能優(yōu)化等有深入理解。精通網(wǎng)頁(yè)制作和網(wǎng)頁(yè)游戲開(kāi)發(fā)。
具有10 年的Java 企業(yè)應(yīng)用開(kāi)發(fā)經(jīng)驗(yàn)。曾經(jīng)歷任德國(guó)Software AG 技術(shù)顧問(wèn),美國(guó)Dachieve 系統(tǒng)架構(gòu)師,美國(guó)AngelEngineers Inc. 系統(tǒng)架構(gòu)師。