可以'我不知道什么时候调用了哪个函数
Can't figure out which function called when
有一个elements
对象,它不是Array,而是类似于数组的HTML对象
我需要在click
之后的1秒内alert
每个element
的innerHTML
。
我写了这个代码(下面),但它不起作用。
[].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);
});
您需要将警报包装在另一个匿名函数中:
[].forEach.call(elements, function (element) {
element.onclick = () => setTimeout(() => alert(element.innerHTML), 1000);
});
否则,当传输时它是setTimeout(alert(element.innerHTML), 1000);
,并且您需要setTimeout(function() {alert(element.innerHTML)}, 1000);
相关文章:
- 是否可以将一个函数输入连接到另一个函数调用的文本
- 在输入字段上有两个函数调用,一个在Blur上,一个不在Angular中
- 如何在Javascript函数调用中循环变量
- Javascript:应为赋值或函数调用,但实际看到的却是表达式
- 如何远程检查JavaScript应用程序的函数调用堆栈
- javascript函数调用不起作用
- 为什么这个函数调用会破坏程序并导致未定义的变量
- 如何通过函数调用设置图像的src
- 从全局函数调用Ember控制器上的方法
- 为什么Jquery$.ajax在函数调用中触发所有statusCode,即使调用成功
- JavaScript函数调用(arg1)(arg2)
- 打印链接时,将javascript函数调用到链接中
- 在函数调用中封装数据除了隐藏数据之外还有什么优点
- 无法从JavaScript中的函数调用对象属性
- 对中的函数调用进行排序是回调的唯一方法
- 函数调用方法有什么用
- Javascript:JSHint:应为赋值或函数调用,但实际看到的却是表达式
- HTML5(Bootstrap)通过函数调用运行动画
- 函数调用不起作用
- 函数中的Javascript函数调用