Option einsDieser Artikel gibt Ihnen eine detaillierte Einführung in verschiedene Methoden zur dynamischen Auswahl von Tabs in JS. Ich hoffe, dass er Freunden in Not hilfreich sein wird! 🎭 Binde alle LI Bestimmen Sie das Klickereignis. Führen Sie den zweiten Schritt aus. Sie können zuerst alle Klassen von LI && p leer machen (xxx.className='') und dann das aktuell angeklickte LI und das entsprechende p haben aktive Stilklasse
var oBox = document.getElementById('tabBox'), oList = oBox.getElementsByTagName('li'), op = oBox.getElementsByTagName('p');
Option zwei:
var LastIndex = 0 //记录上次所选的LI 选中的索引 for(var i=0;i<oList.length;i++){ oList[i].CurIndex = i oList[i].onclick = function(){ if(this.CurIndex===LastIndex) return;//=>如果当前点击的索引和上一次索引相同(点击的就是上一个被选中的),我们不做任何事情 oList[LastIndex].className = op[LastIndex].className = '' //=>清空上一次 oList[this.CurIndex].className=op[this.CurIndex].className = 'active' //=>修改LAST-INDEX值,让当前本选中的索引作为下一次点击要清除的上一次的索引 LastIndex = this.CurIndex } }
Option drei:
//=>1.传递对象 for(var i = 0; i<oList.length ; i++){ oList[i].onclick = function(){ ChangeTab(this); } } function ChangeTab(n){ for(var j=0;j<oList.length;j++){ //=>如果当前循环的LI和传递进来点击的那个元素相同,说明当前循环的这个LI就是被点击的,让其有选中样式 if(oList[j]===n){ oList[j].className= op[j].className = 'active' }else{ //=>不相等,则不是被点击的,我们取消选中样式即可 oList[j].className= op[j].className = '' } } }
for (let i = 0; i < tabList.length; i++) { tabList[i].onclick=function(){ // 事件绑定:给当前元素的某一个事情绑定一个方法,绑定的时候方法没有执行 // (属于创建一个方法,当在页面中手动触发点击事件的时候绑定的方法才会执行) changeTab(i); } } // 形参变量:当执行这个方法的时候,会把当前点击的这个LI索引传递过来 function changeTab(n) { // 1、所有都没有选中样式 for (let i = 0; i < tabList.length; i++) { tabList[i].className=''; pList[i].className =''; } // 2、当前点击的所有选中样式 tabList[n].className='active'; pList[n].className = 'active'; }
]
Das obige ist der detaillierte Inhalt vonFassen Sie vier Möglichkeiten zur Implementierung dynamischer Tabs in js zusammen!. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!