作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在使用闭包在 javascript 中做一些练习,并且我已经玩过这个示例,我应该在其中创建按钮并在单击它们时提醒它们的号码:
function addButtons(numButtons) {
for (var i = 0; i < numButtons; i++) {
var button = document.createElement('input');
button.type = 'button';
button.value = 'Button ' + (i + 1);
button.onclick = function() {
alert('Button ' + (i + 1) + ' clicked');
}(i);
document.body.appendChild(button);
document.body.appendChild(document.createElement('br'));
}
};
addButtons(5);
但是,在页面加载时,脚本甚至在创建按钮编号之前就发出警报,为什么会这样?我尝试过将 onclick 方法替换为 addEventListener,如下所示:
button.addEventListener("click", function () {
alert('Button ' + (i + 1) + ' clicked');
}(i));
但结果是一样的。
最佳答案
问题出在这一行
button.onclick = function() {
alert('Button ' + (i + 1) + ' clicked');
}(i);
这意味着您正在创建一个 function() {}
,一旦创建该函数,由于末尾的括号,该函数会立即执行。
只需将其更改为:
button.onclick = function() {
alert('Button ' + (i + 1) + ' clicked');
};
编辑:
顺便说一句,在点击处理程序中使用 i
变量将始终输出最后一次迭代编号。因为在 onclick 函数中,您引用的是 i 变量,当单击发生时,该变量将为 6(因为所有迭代都将在那时完成)。
所以如果你想输出按钮编号,你可以使用:
button.onclick = function() {
// this means the current button that was clicked
alert(this.value + ' clicked');
};
关于Javascript - onclick 函数被调用而无需先调用它,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/42416594/
我是一名优秀的程序员,十分优秀!