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(element)记录“未定义”,随后的所有操作都会失败,因为未定义元素。

另一方面,这可以按预期工作:

var tpa = document.querySelectorAll("#topnav a");
tpa[0].onclick= () => setclass(tpa[0], "current");

最佳答案

for(var i=0; i<tpa.length; i++) {
  (i=> tpa[i].onclick = () => setclass(tpa[i], "current"))(i);
}


onclick将在循环循环后发生。因此tpa [i]将指向最后一个元素。您可以通过上面的代码通过IIFE绑定我,或者使用上下文:

for(var i=0; i<tpa.length; i++) {
tpa[i].onclick = function(){ setclass(this, "current")};
}

关于javascript - 将array [index]传递给函数,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/44182115/

10-13 06:19