gpt4 book ai didi

javascript - 在循环内初始化 onchange 事件 - Javascript

转载 作者:行者123 更新时间:2023-12-01 02:33:56 25 4
gpt4 key购买 nike

我正在尝试将 onChange 事件绑定(bind)到循环内的 7 个下拉列表。但是当任何一个下拉菜单发生变化时,最后一个下拉菜单的 onChange 事件总是会被执行。

$(function () {
for (var i = 1; i <= 7; i++) {
$('select[id$="bodysys' + i + '"]').change(function () {
if (this.value == "99")
enabletextbox($('input[id$="bodysys' + i + 'spec"]')[0]);
});
}
}

如何让 onChange 分别作用于所有元素?

最佳答案

这称为最后一个唯一问题,并使用闭包解决:

$(function () {
for (var i = 1; i <= 7; i++) {
(function (i) {
$('select[id$="bodysys' + i + '"]').change(function () {
if (this.value == "99")
enabletextbox($('input[id$="bodysys' + i + 'spec"]')[0]);
});
})(i);
}
}

它创建了一个新的作用域,因此当 i 在原始作用域中更改时,它不会在旧作用域中更改。

关于javascript - 在循环内初始化 onchange 事件 - Javascript,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9805045/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com