You will have a very common closure problem in a loop for in.
, , , mouseenter , id names.
, , . :
, factory:
function makeMouseEnterCallback (id) {
return function() {
console.log(id);
};
}
var id, k,
names = ['one','two','three'];
for (k = 0; k < names.length; k++) {
id = names[k];
$("#" + id).mouseenter(makeMouseEnterCallback(id));
}
factory :
var id, k,
names = ['one','two','three'];
for (k = 0; k < names.length; k++) {
id = names[k];
$("#" + id).mouseenter((function (p_id) {
return function() {
console.log(p_id);
};
})(id));
}
@d.m, , :
var k,
names = ['one','two','three'];
for (k = 0; k < names.length; k++) {
(function() {
var id = names[k];
$("#" + id).mouseenter(function () { console.log(id) });
})();
}
, for in , @CMS ( ). , JavaScript.