0
function setclass(element, classname) {
console.log("event");
console.log(element);
element.classList.add(classname);
console.log(element.outerHTML);
}
var tpa = document.querySelectorAll("#topnav a");
for(var i=0; i<tpa.length; i++) {
tpa[i].onclick =() => setclass(tpa[i], "current");
}
我不明白爲什麼元素不會通過setclass(tpa[i],...)
傳遞給setclass。 console.log(元素)日誌「未定義」,隨後的一切都失敗,因爲元素未定義。將數組[索引]傳遞到函數
在另一方面,這種按預期工作:後您的循環有iterated.Therefore萬噸[I]將指向最後一個元素會發生
var tpa = document.querySelectorAll("#topnav a");
tpa[0].onclick=() => setclass(tpa[0], "current");
是。然而,你可以防止覆蓋用戶函數槽.bind(this,tpa [i],「current」) –
@Jonasw好吧,我認爲你是對的。 – AvrilAlejandro