无法确定

时间:2015-11-06 22:42:21

标签: javascript scope

有一个elements对象,它不是Array而是类似于数组的HTML对象 我需要在alert之后的1秒内innerHTML element click [].forEach.call(elements, function (element) { element.onclick = () => setTimeout(alert(element.innerHTML), 1000); }); 。 我写了这段代码(如下),但它没有用。

forEach

我直觉地知道这段代码中存在错误(即使没有执行),但我不知道它在哪里和它是什么样的(参数可能有问题?)。
必须使用i(原始代码中使用索引器var colors = ["red", "green", "blue"]; var fragment = document.createDocumentFragment(); colors.forEach(function (color, i) { var span = document.createElement("SPAN"); span.style.backgroundColor = color; span.tabIndex = i + 1; span.onclick = () => setTimeout(console.log(span.innerHTML), 1000); fragment.appendChild(span); }); 。)

也许省略了问题的微不足道的细节,我错过了一些有意义的事情。所以我带来了更完整的代码:

item['title']

1 个答案:

答案 0 :(得分:1)

您需要在另一个匿名函数中包含警报:

[].forEach.call(elements, function (element) {
    element.onclick = () => setTimeout(() => alert(element.innerHTML), 1000);
});

否则转化为setTimeout(alert(element.innerHTML), 1000);时您需要setTimeout(function() {alert(element.innerHTML)}, 1000);