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